From ec069f466f0497c3fe3576d56232b72b68b8db42 Mon Sep 17 00:00:00 2001 From: rajeev Date: Wed, 18 Sep 2024 11:28:14 +0530 Subject: [PATCH 1/5] fixing release and publish jobs --- .github/workflows/pr.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml index 88513c1..b1869e4 100644 --- a/.github/workflows/pr.yml +++ b/.github/workflows/pr.yml @@ -32,7 +32,7 @@ jobs: publish: name: Publish - if: ${{ (endsWith(github.base_ref, 'main') && (contains(github.head_ref, 'release/')) && github.event.pull_request.merged ) }} + if: ${{ (endsWith(github.base_ref, 'main') && (contains(github.head_ref, 'release/')) || github.event.pull_request.merged ) }} needs: - package runs-on: ubuntu-latest @@ -77,7 +77,7 @@ jobs: release: name: Release - if: ${{ (endsWith(github.base_ref, 'main') && (contains(github.head_ref, 'release/')) && github.event.pull_request.merged ) }} + if: ${{ (endsWith(github.base_ref, 'main') && (contains(github.head_ref, 'release/')) || github.event.pull_request.merged ) }} needs: - publish runs-on: ubuntu-latest From 3df9918166f655920b7b8128af109808a0cce610 Mon Sep 17 00:00:00 2001 From: rajeev Date: Thu, 19 Sep 2024 11:27:39 +0530 Subject: [PATCH 2/5] updating version and doing some cleanup to pipline --- .github/workflows/pr.yml | 29 +++++++++-------------------- 1 file changed, 9 insertions(+), 20 deletions(-) diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml index b1869e4..e0817f4 100644 --- a/.github/workflows/pr.yml +++ b/.github/workflows/pr.yml @@ -19,13 +19,13 @@ jobs: - name: Tool Versions run: npm --version - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: npm Package run: | cd WebHelpDocs npm pack - name: Upload Artifacts - uses: actions/upload-artifact@v4.4.0 + uses: actions/upload-artifact@v4 with: name: WebHelpDocs path: ./WebHelpDocs/*.tgz @@ -46,27 +46,15 @@ jobs: steps: - name: Tool Versions run: npm --version - - uses: actions/setup-node@v3 + - uses: actions/setup-node@v4 with: node-version: '20.x' registry-url: 'https://npm.pkg.github.com' scope: '@tektronix' - name: Checkout - uses: actions/checkout@v3 - with: - set-safe-directory: '*' - # - name: Get Tagged Version - # id: lasttag - # run: | - # V="${GITHUB_REF#refs/tags/v}" - # CL="${V%-*}" - # echo "version=${V}" >> $GITHUB_OUTPUT - # echo "cl_version=${CL}" >> $GITHUB_OUTPUT - # # set version to RC version if this is a tagged build - # npm version --no-git-tag-version --allow-same-version "$V" - # if: startsWith(github.ref, 'refs/tags/') + uses: actions/checkout@v4 - name: Get Artifacts - uses: actions/download-artifact@v4.1.8 + uses: actions/download-artifact@v4 with: name: WebHelpDocs - name: publish pack @@ -83,7 +71,7 @@ jobs: runs-on: ubuntu-latest steps: - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Get Tagged Version id: lasttag run: | @@ -100,7 +88,6 @@ jobs: uses: ncipollo/release-action@v1 with: name: ${{steps.lasttag.outputs.version}} - artifacts: target/*,sbom/**/* body: | ## Features Requests / Bugs @@ -114,7 +101,9 @@ jobs: ${{steps.changelog.outputs.description}} - prerelease: true + prerelease: ${{(! github.event.pull_request.merged) || (github.event.pull_request.merged && ! contains(github.head_ref, 'release/'))}} + commit: ${{steps.lasttag.outputs.commit}} makeLatest: true + tag: ${{steps.lasttag.outputs.version}} From 69ff940394547d4929183dc624f814462b496253 Mon Sep 17 00:00:00 2001 From: rajeev Date: Thu, 19 Sep 2024 17:33:15 +0530 Subject: [PATCH 3/5] updating condition when this pipilne should trigger --- .github/workflows/pr.yml | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml index e0817f4..69efeec 100644 --- a/.github/workflows/pr.yml +++ b/.github/workflows/pr.yml @@ -2,6 +2,11 @@ name: Pull Request on: pull_request: + types: + - opened + - reopened + - synchronize + - closed push: tags: - '*' @@ -61,7 +66,7 @@ jobs: run: | npm publish *.tgz env: - NODE_AUTH_TOKEN: ${{secrets.GITHUB_TOKEN}} + NODE_AUTH_TOKEN: ${{ secrets.GITHUB_TOKEN }} release: name: Release From 76c51b04e1977d03ae6cfe5569351bb87518f3c0 Mon Sep 17 00:00:00 2001 From: rajeev Date: Thu, 19 Sep 2024 19:54:06 +0530 Subject: [PATCH 4/5] fixing issue Could not find CHANGELOG entry for version --- .github/workflows/pr.yml | 32 ++++++++++++++++++++++++++++++-- CHANGELOG.md | 2 +- 2 files changed, 31 insertions(+), 3 deletions(-) diff --git a/.github/workflows/pr.yml b/.github/workflows/pr.yml index 69efeec..a9382b0 100644 --- a/.github/workflows/pr.yml +++ b/.github/workflows/pr.yml @@ -80,10 +80,38 @@ jobs: - name: Get Tagged Version id: lasttag run: | - V="${GITHUB_REF#refs/tags/v}" - CL="${V%-*}" + COMMIT="${{github.sha}}" + if ${{contains(github.head_ref, 'release/')}}; then + V="${{github.head_ref}}" + V="${V#release/}" + else + V="$(npm pkg get version)" + echo "Extracted Version: $V" + V="$(echo v"$V" | sed 's/\"//g')" + echo "Cleaned up Version: $V" + fi + + # Check to see if the version tag already exists + # If it does, print a message and exit with an error code + if [ $(git tag --list "$V") ]; then + echo "Version tag already exists. Did you bump the version number?" + exit 1 + fi + + # Create an RC release if + # 1) This PR is a release branch that hasn't been merged to main. + # 2) This is a feature branch being merged into the main branch. + if ${{(! github.event.pull_request.merged && contains(github.head_ref, 'release/')) || (github.event.pull_request.merged && !contains(github.head_ref, 'release/'))}}; then + V="${V}-$(git tag --list ${V}* | wc -l)" + echo "RC Version: $V" + fi + + CL=${V#v} + CL=${CL%-*} + echo "version=${V}" >> $GITHUB_OUTPUT echo "cl_version=${CL}" >> $GITHUB_OUTPUT + echo "commit=${COMMIT}" >> $GITHUB_OUTPUT - name: Get Changelog for this Tag id: changelog uses: coditory/changelog-parser@v1 diff --git a/CHANGELOG.md b/CHANGELOG.md index f0947c5..664f054 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,6 @@ # Change Log -All notable changes to the "keithley_instrument_libraries" npm package will be documented in this file. +All notable changes to the "web-help-documents" npm package will be documented in this file. This project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). From a8329c10031634fa7011fcab5b829b9ad6a37bbd Mon Sep 17 00:00:00 2001 From: rajeev Date: Fri, 20 Sep 2024 10:02:41 +0530 Subject: [PATCH 5/5] Adding webhelp files for 2601B-PULSE --- WebHelpDocs/2601B-PULSE/10835.htm | 44 + WebHelpDocs/2601B-PULSE/10905.htm | 50 + WebHelpDocs/2601B-PULSE/11274.htm | 44 + WebHelpDocs/2601B-PULSE/11382.htm | 61 + WebHelpDocs/2601B-PULSE/11440.htm | 79 + WebHelpDocs/2601B-PULSE/11500.htm | 202 ++ WebHelpDocs/2601B-PULSE/11532.htm | 44 + WebHelpDocs/2601B-PULSE/11584.htm | 46 + WebHelpDocs/2601B-PULSE/11613.htm | 46 + WebHelpDocs/2601B-PULSE/11655.htm | 48 + WebHelpDocs/2601B-PULSE/11848.htm | 44 + WebHelpDocs/2601B-PULSE/11993.htm | 44 + WebHelpDocs/2601B-PULSE/11998.htm | 45 + WebHelpDocs/2601B-PULSE/12001.htm | 48 + WebHelpDocs/2601B-PULSE/12044.htm | 43 + WebHelpDocs/2601B-PULSE/12125.htm | 45 + WebHelpDocs/2601B-PULSE/12137.htm | 45 + WebHelpDocs/2601B-PULSE/12175.htm | 50 + WebHelpDocs/2601B-PULSE/12177.htm | 116 ++ WebHelpDocs/2601B-PULSE/12181.htm | 116 ++ WebHelpDocs/2601B-PULSE/12184.htm | 186 ++ WebHelpDocs/2601B-PULSE/12190.htm | 109 + WebHelpDocs/2601B-PULSE/12192.htm | 187 ++ WebHelpDocs/2601B-PULSE/12194.htm | 49 + WebHelpDocs/2601B-PULSE/12259.htm | 82 + WebHelpDocs/2601B-PULSE/12451.htm | 44 + WebHelpDocs/2601B-PULSE/12571.htm | 230 +++ WebHelpDocs/2601B-PULSE/12893.htm | 71 + WebHelpDocs/2601B-PULSE/12911.htm | 51 + WebHelpDocs/2601B-PULSE/12913.htm | 50 + WebHelpDocs/2601B-PULSE/12914.htm | 42 + WebHelpDocs/2601B-PULSE/12950.htm | 45 + WebHelpDocs/2601B-PULSE/12951.htm | 139 ++ WebHelpDocs/2601B-PULSE/12953.htm | 156 ++ WebHelpDocs/2601B-PULSE/12954.htm | 45 + WebHelpDocs/2601B-PULSE/12955.htm | 138 ++ WebHelpDocs/2601B-PULSE/12957.htm | 141 ++ WebHelpDocs/2601B-PULSE/12958.htm | 44 + WebHelpDocs/2601B-PULSE/12959.htm | 121 ++ WebHelpDocs/2601B-PULSE/13401.htm | 46 + WebHelpDocs/2601B-PULSE/13605.htm | 47 + WebHelpDocs/2601B-PULSE/13629.htm | 48 + WebHelpDocs/2601B-PULSE/13811.htm | 72 + WebHelpDocs/2601B-PULSE/13933.htm | 94 + WebHelpDocs/2601B-PULSE/13943.htm | 98 + WebHelpDocs/2601B-PULSE/13949.htm | 93 + WebHelpDocs/2601B-PULSE/13986.htm | 119 ++ WebHelpDocs/2601B-PULSE/13987.htm | 111 ++ WebHelpDocs/2601B-PULSE/13988.htm | 123 ++ WebHelpDocs/2601B-PULSE/13989.htm | 95 + WebHelpDocs/2601B-PULSE/13990.htm | 107 + WebHelpDocs/2601B-PULSE/14072.htm | 59 + WebHelpDocs/2601B-PULSE/14073.htm | 105 + WebHelpDocs/2601B-PULSE/14074.htm | 141 ++ WebHelpDocs/2601B-PULSE/14076.htm | 96 + WebHelpDocs/2601B-PULSE/14077.htm | 153 ++ WebHelpDocs/2601B-PULSE/14078.htm | 102 + WebHelpDocs/2601B-PULSE/14079.htm | 164 ++ WebHelpDocs/2601B-PULSE/14080.htm | 108 + WebHelpDocs/2601B-PULSE/14081.htm | 70 + WebHelpDocs/2601B-PULSE/14082.htm | 110 + WebHelpDocs/2601B-PULSE/14084.htm | 96 + WebHelpDocs/2601B-PULSE/14085.htm | 92 + WebHelpDocs/2601B-PULSE/14086.htm | 92 + WebHelpDocs/2601B-PULSE/14089.htm | 100 + WebHelpDocs/2601B-PULSE/14090.htm | 124 ++ WebHelpDocs/2601B-PULSE/14126.htm | 90 + WebHelpDocs/2601B-PULSE/14127.htm | 46 + WebHelpDocs/2601B-PULSE/14129.htm | 95 + WebHelpDocs/2601B-PULSE/14435.htm | 95 + WebHelpDocs/2601B-PULSE/14632.htm | 109 + WebHelpDocs/2601B-PULSE/14634.htm | 109 + WebHelpDocs/2601B-PULSE/14635.htm | 109 + WebHelpDocs/2601B-PULSE/14636.htm | 112 ++ WebHelpDocs/2601B-PULSE/14637.htm | 113 ++ WebHelpDocs/2601B-PULSE/14638.htm | 121 ++ WebHelpDocs/2601B-PULSE/14639.htm | 115 ++ WebHelpDocs/2601B-PULSE/14640.htm | 126 ++ WebHelpDocs/2601B-PULSE/14641.htm | 114 ++ WebHelpDocs/2601B-PULSE/14642.htm | 114 ++ WebHelpDocs/2601B-PULSE/14653.htm | 51 + WebHelpDocs/2601B-PULSE/14654.htm | 127 ++ WebHelpDocs/2601B-PULSE/14655.htm | 96 + WebHelpDocs/2601B-PULSE/14656.htm | 102 + WebHelpDocs/2601B-PULSE/14657.htm | 109 + WebHelpDocs/2601B-PULSE/14658.htm | 131 ++ WebHelpDocs/2601B-PULSE/14668.htm | 102 + WebHelpDocs/2601B-PULSE/14669.htm | 100 + WebHelpDocs/2601B-PULSE/14670.htm | 91 + WebHelpDocs/2601B-PULSE/14671.htm | 93 + WebHelpDocs/2601B-PULSE/14672.htm | 99 + WebHelpDocs/2601B-PULSE/14674.htm | 172 ++ WebHelpDocs/2601B-PULSE/14675.htm | 101 + WebHelpDocs/2601B-PULSE/14677.htm | 92 + WebHelpDocs/2601B-PULSE/14679.htm | 108 + WebHelpDocs/2601B-PULSE/14680.htm | 104 + WebHelpDocs/2601B-PULSE/14681.htm | 97 + WebHelpDocs/2601B-PULSE/14682.htm | 95 + WebHelpDocs/2601B-PULSE/14699.htm | 72 + WebHelpDocs/2601B-PULSE/14700.htm | 121 ++ WebHelpDocs/2601B-PULSE/14702.htm | 160 ++ WebHelpDocs/2601B-PULSE/14703.htm | 172 ++ WebHelpDocs/2601B-PULSE/14705.htm | 111 ++ WebHelpDocs/2601B-PULSE/14706.htm | 98 + WebHelpDocs/2601B-PULSE/14707.htm | 94 + WebHelpDocs/2601B-PULSE/14708.htm | 110 + WebHelpDocs/2601B-PULSE/14709.htm | 93 + WebHelpDocs/2601B-PULSE/14711.htm | 117 ++ WebHelpDocs/2601B-PULSE/14712.htm | 157 ++ WebHelpDocs/2601B-PULSE/14715.htm | 72 + WebHelpDocs/2601B-PULSE/14716.htm | 80 + WebHelpDocs/2601B-PULSE/14717.htm | 101 + WebHelpDocs/2601B-PULSE/14719.htm | 300 +++ WebHelpDocs/2601B-PULSE/14739.htm | 93 + WebHelpDocs/2601B-PULSE/14740.htm | 185 ++ WebHelpDocs/2601B-PULSE/14748.htm | 47 + WebHelpDocs/2601B-PULSE/14749.htm | 71 + WebHelpDocs/2601B-PULSE/14750.htm | 94 + WebHelpDocs/2601B-PULSE/14756.htm | 102 + WebHelpDocs/2601B-PULSE/14757.htm | 95 + WebHelpDocs/2601B-PULSE/14758.htm | 74 + WebHelpDocs/2601B-PULSE/14759.htm | 97 + WebHelpDocs/2601B-PULSE/14760.htm | 104 + WebHelpDocs/2601B-PULSE/14761.htm | 114 ++ WebHelpDocs/2601B-PULSE/14769.htm | 71 + WebHelpDocs/2601B-PULSE/14771.htm | 86 + WebHelpDocs/2601B-PULSE/14772.htm | 116 ++ WebHelpDocs/2601B-PULSE/14786.htm | 118 ++ WebHelpDocs/2601B-PULSE/14787.htm | 165 ++ WebHelpDocs/2601B-PULSE/14788.htm | 144 ++ WebHelpDocs/2601B-PULSE/14789.htm | 146 ++ WebHelpDocs/2601B-PULSE/14795.htm | 54 + WebHelpDocs/2601B-PULSE/14797.htm | 104 + WebHelpDocs/2601B-PULSE/14801.htm | 104 + WebHelpDocs/2601B-PULSE/14803.htm | 107 + WebHelpDocs/2601B-PULSE/14808.htm | 114 ++ WebHelpDocs/2601B-PULSE/14810.htm | 105 + WebHelpDocs/2601B-PULSE/14811.htm | 116 ++ WebHelpDocs/2601B-PULSE/14812.htm | 104 + WebHelpDocs/2601B-PULSE/14814.htm | 110 + WebHelpDocs/2601B-PULSE/14815.htm | 104 + WebHelpDocs/2601B-PULSE/14824.htm | 102 + WebHelpDocs/2601B-PULSE/14859.htm | 45 + WebHelpDocs/2601B-PULSE/14860.htm | 100 + WebHelpDocs/2601B-PULSE/14868.htm | 99 + WebHelpDocs/2601B-PULSE/14870.htm | 75 + WebHelpDocs/2601B-PULSE/14872.htm | 115 ++ WebHelpDocs/2601B-PULSE/14873.htm | 124 ++ WebHelpDocs/2601B-PULSE/14874.htm | 192 ++ WebHelpDocs/2601B-PULSE/14875.htm | 122 ++ WebHelpDocs/2601B-PULSE/14877.htm | 135 ++ WebHelpDocs/2601B-PULSE/14890.htm | 84 + WebHelpDocs/2601B-PULSE/14891.htm | 97 + WebHelpDocs/2601B-PULSE/14892.htm | 96 + WebHelpDocs/2601B-PULSE/14893.htm | 93 + WebHelpDocs/2601B-PULSE/14894.htm | 81 + WebHelpDocs/2601B-PULSE/14895.htm | 71 + WebHelpDocs/2601B-PULSE/14896.htm | 192 ++ WebHelpDocs/2601B-PULSE/14897.htm | 93 + WebHelpDocs/2601B-PULSE/14898.htm | 106 + WebHelpDocs/2601B-PULSE/14899.htm | 97 + WebHelpDocs/2601B-PULSE/14900.htm | 95 + WebHelpDocs/2601B-PULSE/14902.htm | 95 + WebHelpDocs/2601B-PULSE/14903.htm | 92 + WebHelpDocs/2601B-PULSE/14904.htm | 96 + WebHelpDocs/2601B-PULSE/14905.htm | 94 + WebHelpDocs/2601B-PULSE/14906.htm | 96 + WebHelpDocs/2601B-PULSE/14907.htm | 95 + WebHelpDocs/2601B-PULSE/14908.htm | 95 + WebHelpDocs/2601B-PULSE/14909.htm | 101 + WebHelpDocs/2601B-PULSE/14910.htm | 94 + WebHelpDocs/2601B-PULSE/14911.htm | 90 + WebHelpDocs/2601B-PULSE/14912.htm | 92 + WebHelpDocs/2601B-PULSE/14913.htm | 92 + WebHelpDocs/2601B-PULSE/14914.htm | 92 + WebHelpDocs/2601B-PULSE/14915.htm | 93 + WebHelpDocs/2601B-PULSE/14916.htm | 92 + WebHelpDocs/2601B-PULSE/14917.htm | 93 + WebHelpDocs/2601B-PULSE/14918.htm | 92 + WebHelpDocs/2601B-PULSE/14919.htm | 92 + WebHelpDocs/2601B-PULSE/14920.htm | 92 + WebHelpDocs/2601B-PULSE/14921.htm | 99 + WebHelpDocs/2601B-PULSE/14922.htm | 95 + WebHelpDocs/2601B-PULSE/14923.htm | 99 + WebHelpDocs/2601B-PULSE/14924.htm | 103 + WebHelpDocs/2601B-PULSE/14925.htm | 82 + WebHelpDocs/2601B-PULSE/14926.htm | 97 + WebHelpDocs/2601B-PULSE/14927.htm | 103 + WebHelpDocs/2601B-PULSE/14928.htm | 199 ++ WebHelpDocs/2601B-PULSE/14929.htm | 104 + WebHelpDocs/2601B-PULSE/14930.htm | 100 + WebHelpDocs/2601B-PULSE/14931.htm | 99 + WebHelpDocs/2601B-PULSE/14933.htm | 107 + WebHelpDocs/2601B-PULSE/15007.htm | 83 + WebHelpDocs/2601B-PULSE/15008.htm | 95 + WebHelpDocs/2601B-PULSE/15010.htm | 107 + WebHelpDocs/2601B-PULSE/15011.htm | 92 + WebHelpDocs/2601B-PULSE/15012.htm | 104 + WebHelpDocs/2601B-PULSE/15014.htm | 96 + WebHelpDocs/2601B-PULSE/15015.htm | 98 + WebHelpDocs/2601B-PULSE/15016.htm | 97 + WebHelpDocs/2601B-PULSE/15017.htm | 93 + WebHelpDocs/2601B-PULSE/15018.htm | 96 + WebHelpDocs/2601B-PULSE/15019.htm | 95 + WebHelpDocs/2601B-PULSE/15020.htm | 105 + WebHelpDocs/2601B-PULSE/15021.htm | 122 ++ WebHelpDocs/2601B-PULSE/15022.htm | 94 + WebHelpDocs/2601B-PULSE/15041.htm | 108 + WebHelpDocs/2601B-PULSE/15042.htm | 109 + WebHelpDocs/2601B-PULSE/15050.htm | 100 + WebHelpDocs/2601B-PULSE/15054.htm | 86 + WebHelpDocs/2601B-PULSE/15058.htm | 126 ++ WebHelpDocs/2601B-PULSE/15061.htm | 53 + WebHelpDocs/2601B-PULSE/15062.htm | 63 + WebHelpDocs/2601B-PULSE/15063.htm | 106 + WebHelpDocs/2601B-PULSE/15064.htm | 129 ++ WebHelpDocs/2601B-PULSE/15067.htm | 49 + WebHelpDocs/2601B-PULSE/15068.htm | 97 + WebHelpDocs/2601B-PULSE/15069.htm | 97 + WebHelpDocs/2601B-PULSE/15070.htm | 96 + WebHelpDocs/2601B-PULSE/15071.htm | 97 + WebHelpDocs/2601B-PULSE/15072.htm | 105 + WebHelpDocs/2601B-PULSE/15073.htm | 92 + WebHelpDocs/2601B-PULSE/15081.htm | 95 + WebHelpDocs/2601B-PULSE/15083.htm | 94 + WebHelpDocs/2601B-PULSE/15088.htm | 83 + WebHelpDocs/2601B-PULSE/15089.htm | 86 + WebHelpDocs/2601B-PULSE/15090.htm | 96 + WebHelpDocs/2601B-PULSE/15091.htm | 90 + WebHelpDocs/2601B-PULSE/15092.htm | 95 + WebHelpDocs/2601B-PULSE/15093.htm | 105 + WebHelpDocs/2601B-PULSE/15094.htm | 103 + WebHelpDocs/2601B-PULSE/15095.htm | 102 + WebHelpDocs/2601B-PULSE/15096.htm | 93 + WebHelpDocs/2601B-PULSE/15098.htm | 99 + WebHelpDocs/2601B-PULSE/15099.htm | 132 ++ WebHelpDocs/2601B-PULSE/15100.htm | 132 ++ WebHelpDocs/2601B-PULSE/15105.htm | 102 + WebHelpDocs/2601B-PULSE/15107.htm | 108 + WebHelpDocs/2601B-PULSE/15109.htm | 133 ++ WebHelpDocs/2601B-PULSE/15112.htm | 98 + WebHelpDocs/2601B-PULSE/15113.htm | 103 + WebHelpDocs/2601B-PULSE/15114.htm | 103 + WebHelpDocs/2601B-PULSE/15116.htm | 96 + WebHelpDocs/2601B-PULSE/15120.htm | 118 ++ WebHelpDocs/2601B-PULSE/15122.htm | 139 ++ WebHelpDocs/2601B-PULSE/15123.htm | 103 + WebHelpDocs/2601B-PULSE/15124.htm | 102 + WebHelpDocs/2601B-PULSE/15127.htm | 102 + WebHelpDocs/2601B-PULSE/15128.htm | 110 + WebHelpDocs/2601B-PULSE/15129.htm | 110 + WebHelpDocs/2601B-PULSE/15130.htm | 92 + WebHelpDocs/2601B-PULSE/15131.htm | 96 + WebHelpDocs/2601B-PULSE/15132.htm | 107 + WebHelpDocs/2601B-PULSE/15133.htm | 106 + WebHelpDocs/2601B-PULSE/15134.htm | 118 ++ WebHelpDocs/2601B-PULSE/15135.htm | 108 + WebHelpDocs/2601B-PULSE/15136.htm | 81 + WebHelpDocs/2601B-PULSE/15137.htm | 94 + WebHelpDocs/2601B-PULSE/15139.htm | 103 + WebHelpDocs/2601B-PULSE/15141.htm | 98 + WebHelpDocs/2601B-PULSE/15142.htm | 98 + WebHelpDocs/2601B-PULSE/15143.htm | 132 ++ WebHelpDocs/2601B-PULSE/15144.htm | 93 + WebHelpDocs/2601B-PULSE/15145.htm | 93 + WebHelpDocs/2601B-PULSE/15149.htm | 101 + WebHelpDocs/2601B-PULSE/15151.htm | 96 + WebHelpDocs/2601B-PULSE/15155.htm | 92 + WebHelpDocs/2601B-PULSE/15156.htm | 95 + WebHelpDocs/2601B-PULSE/15157.htm | 87 + WebHelpDocs/2601B-PULSE/15158.htm | 205 ++ WebHelpDocs/2601B-PULSE/15159.htm | 93 + WebHelpDocs/2601B-PULSE/15160.htm | 97 + WebHelpDocs/2601B-PULSE/15161.htm | 129 ++ WebHelpDocs/2601B-PULSE/15163.htm | 120 ++ WebHelpDocs/2601B-PULSE/15165.htm | 205 ++ WebHelpDocs/2601B-PULSE/15166.htm | 94 + WebHelpDocs/2601B-PULSE/15167.htm | 93 + WebHelpDocs/2601B-PULSE/15168.htm | 95 + WebHelpDocs/2601B-PULSE/15169.htm | 101 + WebHelpDocs/2601B-PULSE/15170.htm | 87 + WebHelpDocs/2601B-PULSE/15171.htm | 205 ++ WebHelpDocs/2601B-PULSE/15172.htm | 120 ++ WebHelpDocs/2601B-PULSE/15173.htm | 93 + WebHelpDocs/2601B-PULSE/15174.htm | 93 + WebHelpDocs/2601B-PULSE/15175.htm | 93 + WebHelpDocs/2601B-PULSE/15176.htm | 100 + WebHelpDocs/2601B-PULSE/15177.htm | 127 ++ WebHelpDocs/2601B-PULSE/15178.htm | 99 + WebHelpDocs/2601B-PULSE/15179.htm | 103 + WebHelpDocs/2601B-PULSE/15180.htm | 119 ++ WebHelpDocs/2601B-PULSE/15181.htm | 107 + WebHelpDocs/2601B-PULSE/15182.htm | 127 ++ WebHelpDocs/2601B-PULSE/15183.htm | 97 + WebHelpDocs/2601B-PULSE/15184.htm | 204 ++ WebHelpDocs/2601B-PULSE/15280.htm | 113 ++ WebHelpDocs/2601B-PULSE/15281.htm | 120 ++ WebHelpDocs/2601B-PULSE/15282.htm | 85 + WebHelpDocs/2601B-PULSE/15285.htm | 94 + WebHelpDocs/2601B-PULSE/15286.htm | 91 + WebHelpDocs/2601B-PULSE/15287.htm | 95 + WebHelpDocs/2601B-PULSE/15288.htm | 101 + WebHelpDocs/2601B-PULSE/15289.htm | 99 + WebHelpDocs/2601B-PULSE/15290.htm | 106 + WebHelpDocs/2601B-PULSE/15291.htm | 94 + WebHelpDocs/2601B-PULSE/15292.htm | 97 + WebHelpDocs/2601B-PULSE/15293.htm | 95 + WebHelpDocs/2601B-PULSE/15294.htm | 98 + WebHelpDocs/2601B-PULSE/15295.htm | 198 ++ WebHelpDocs/2601B-PULSE/15296.htm | 105 + WebHelpDocs/2601B-PULSE/15297.htm | 98 + WebHelpDocs/2601B-PULSE/15298.htm | 97 + WebHelpDocs/2601B-PULSE/15300.htm | 109 + WebHelpDocs/2601B-PULSE/15301.htm | 102 + WebHelpDocs/2601B-PULSE/15302.htm | 97 + WebHelpDocs/2601B-PULSE/15424.htm | 45 + WebHelpDocs/2601B-PULSE/15785.htm | 91 + WebHelpDocs/2601B-PULSE/15786.htm | 99 + WebHelpDocs/2601B-PULSE/15787.htm | 101 + WebHelpDocs/2601B-PULSE/15788.htm | 99 + WebHelpDocs/2601B-PULSE/15790.htm | 116 ++ WebHelpDocs/2601B-PULSE/15791.htm | 70 + WebHelpDocs/2601B-PULSE/15792.htm | 91 + WebHelpDocs/2601B-PULSE/15793.htm | 91 + WebHelpDocs/2601B-PULSE/15794.htm | 102 + WebHelpDocs/2601B-PULSE/15795.htm | 114 ++ WebHelpDocs/2601B-PULSE/15796.htm | 98 + WebHelpDocs/2601B-PULSE/15797.htm | 100 + WebHelpDocs/2601B-PULSE/15798.htm | 98 + WebHelpDocs/2601B-PULSE/15800.htm | 107 + WebHelpDocs/2601B-PULSE/15801.htm | 103 + WebHelpDocs/2601B-PULSE/15820.htm | 104 + WebHelpDocs/2601B-PULSE/15830.htm | 338 ++++ WebHelpDocs/2601B-PULSE/15831.htm | 323 +++ WebHelpDocs/2601B-PULSE/15833.htm | 553 +++++ WebHelpDocs/2601B-PULSE/15836.htm | 208 ++ WebHelpDocs/2601B-PULSE/15837.htm | 596 ++++++ WebHelpDocs/2601B-PULSE/15838.htm | 504 +++++ WebHelpDocs/2601B-PULSE/15839.htm | 548 +++++ WebHelpDocs/2601B-PULSE/15840.htm | 515 +++++ WebHelpDocs/2601B-PULSE/15841.htm | 506 +++++ WebHelpDocs/2601B-PULSE/15842.htm | 195 ++ WebHelpDocs/2601B-PULSE/15844.htm | 195 ++ WebHelpDocs/2601B-PULSE/15845.htm | 553 +++++ WebHelpDocs/2601B-PULSE/15846.htm | 195 ++ WebHelpDocs/2601B-PULSE/15847.htm | 507 +++++ WebHelpDocs/2601B-PULSE/15849.htm | 225 +++ WebHelpDocs/2601B-PULSE/15852.htm | 596 ++++++ WebHelpDocs/2601B-PULSE/15861.htm | 81 + WebHelpDocs/2601B-PULSE/15862.htm | 458 +++++ WebHelpDocs/2601B-PULSE/15863.htm | 595 ++++++ WebHelpDocs/2601B-PULSE/15864.htm | 597 ++++++ WebHelpDocs/2601B-PULSE/15865.htm | 597 ++++++ WebHelpDocs/2601B-PULSE/15866.htm | 597 ++++++ WebHelpDocs/2601B-PULSE/15867.htm | 547 +++++ WebHelpDocs/2601B-PULSE/15965.htm | 68 + WebHelpDocs/2601B-PULSE/16803.htm | 46 + WebHelpDocs/2601B-PULSE/16805.htm | 59 + WebHelpDocs/2601B-PULSE/16851.htm | 91 + WebHelpDocs/2601B-PULSE/16852.htm | 103 + WebHelpDocs/2601B-PULSE/16853.htm | 90 + WebHelpDocs/2601B-PULSE/16856.htm | 93 + WebHelpDocs/2601B-PULSE/16862.htm | 100 + WebHelpDocs/2601B-PULSE/16863.htm | 111 ++ WebHelpDocs/2601B-PULSE/16867.htm | 105 + WebHelpDocs/2601B-PULSE/16978.htm | 85 + WebHelpDocs/2601B-PULSE/17029.htm | 47 + WebHelpDocs/2601B-PULSE/17030.htm | 67 + WebHelpDocs/2601B-PULSE/17040.htm | 109 + WebHelpDocs/2601B-PULSE/17109.htm | 101 + WebHelpDocs/2601B-PULSE/17112.htm | 71 + WebHelpDocs/2601B-PULSE/17268.htm | 47 + WebHelpDocs/2601B-PULSE/17630.htm | 96 + WebHelpDocs/2601B-PULSE/17645.htm | 129 ++ WebHelpDocs/2601B-PULSE/17666.htm | 94 + WebHelpDocs/2601B-PULSE/17668.htm | 97 + WebHelpDocs/2601B-PULSE/17669.htm | 95 + WebHelpDocs/2601B-PULSE/17679.htm | 216 ++ WebHelpDocs/2601B-PULSE/17682.htm | 212 ++ WebHelpDocs/2601B-PULSE/17684.htm | 223 +++ WebHelpDocs/2601B-PULSE/17688.htm | 210 ++ WebHelpDocs/2601B-PULSE/17691.htm | 100 + WebHelpDocs/2601B-PULSE/17719.htm | 108 + WebHelpDocs/2601B-PULSE/17785.htm | 100 + WebHelpDocs/2601B-PULSE/17789.htm | 44 + WebHelpDocs/2601B-PULSE/17852.htm | 49 + WebHelpDocs/2601B-PULSE/17853.htm | 45 + WebHelpDocs/2601B-PULSE/17854.htm | 47 + WebHelpDocs/2601B-PULSE/17855.htm | 45 + WebHelpDocs/2601B-PULSE/17856.htm | 46 + WebHelpDocs/2601B-PULSE/17857.htm | 44 + WebHelpDocs/2601B-PULSE/17860.htm | 52 + WebHelpDocs/2601B-PULSE/18551.htm | 101 + WebHelpDocs/2601B-PULSE/18552.htm | 103 + WebHelpDocs/2601B-PULSE/18554.htm | 233 +++ WebHelpDocs/2601B-PULSE/18556.htm | 94 + WebHelpDocs/2601B-PULSE/18560.htm | 44 + WebHelpDocs/2601B-PULSE/18832.htm | 121 ++ WebHelpDocs/2601B-PULSE/18833.htm | 82 + WebHelpDocs/2601B-PULSE/18841.htm | 99 + WebHelpDocs/2601B-PULSE/19138.htm | 108 + WebHelpDocs/2601B-PULSE/19382.htm | 139 ++ WebHelpDocs/2601B-PULSE/19389.htm | 46 + WebHelpDocs/2601B-PULSE/19423.htm | 48 + WebHelpDocs/2601B-PULSE/19424.htm | 52 + WebHelpDocs/2601B-PULSE/19425.htm | 54 + WebHelpDocs/2601B-PULSE/19432.htm | 54 + WebHelpDocs/2601B-PULSE/19516.htm | 47 + WebHelpDocs/2601B-PULSE/19536.htm | 46 + WebHelpDocs/2601B-PULSE/19550.htm | 44 + WebHelpDocs/2601B-PULSE/19551.htm | 44 + WebHelpDocs/2601B-PULSE/19552.htm | 44 + WebHelpDocs/2601B-PULSE/19553.htm | 44 + WebHelpDocs/2601B-PULSE/19554.htm | 44 + WebHelpDocs/2601B-PULSE/19555.htm | 44 + WebHelpDocs/2601B-PULSE/19556.htm | 44 + WebHelpDocs/2601B-PULSE/19557.htm | 44 + WebHelpDocs/2601B-PULSE/19558.htm | 44 + WebHelpDocs/2601B-PULSE/19559.htm | 44 + WebHelpDocs/2601B-PULSE/19560.htm | 44 + WebHelpDocs/2601B-PULSE/19561.htm | 44 + WebHelpDocs/2601B-PULSE/19562.htm | 44 + WebHelpDocs/2601B-PULSE/19563.htm | 44 + WebHelpDocs/2601B-PULSE/19564.htm | 44 + WebHelpDocs/2601B-PULSE/19565.htm | 44 + WebHelpDocs/2601B-PULSE/19566.htm | 44 + WebHelpDocs/2601B-PULSE/19567.htm | 44 + WebHelpDocs/2601B-PULSE/19568.htm | 44 + WebHelpDocs/2601B-PULSE/19569.htm | 44 + WebHelpDocs/2601B-PULSE/19570.htm | 44 + WebHelpDocs/2601B-PULSE/19571.htm | 44 + WebHelpDocs/2601B-PULSE/19572.htm | 44 + WebHelpDocs/2601B-PULSE/19573.htm | 44 + WebHelpDocs/2601B-PULSE/19574.htm | 44 + WebHelpDocs/2601B-PULSE/19575.htm | 44 + WebHelpDocs/2601B-PULSE/19576.htm | 44 + WebHelpDocs/2601B-PULSE/19578.htm | 44 + WebHelpDocs/2601B-PULSE/19579.htm | 44 + WebHelpDocs/2601B-PULSE/19580.htm | 44 + WebHelpDocs/2601B-PULSE/19581.htm | 44 + WebHelpDocs/2601B-PULSE/19582.htm | 45 + WebHelpDocs/2601B-PULSE/19632.htm | 45 + WebHelpDocs/2601B-PULSE/19914.htm | 130 ++ WebHelpDocs/2601B-PULSE/19915.htm | 130 ++ WebHelpDocs/2601B-PULSE/19916.htm | 129 ++ WebHelpDocs/2601B-PULSE/19917.htm | 115 ++ WebHelpDocs/2601B-PULSE/19918.htm | 127 ++ WebHelpDocs/2601B-PULSE/19919.htm | 129 ++ WebHelpDocs/2601B-PULSE/19920.htm | 115 ++ WebHelpDocs/2601B-PULSE/19922.htm | 117 ++ WebHelpDocs/2601B-PULSE/19929.htm | 104 + WebHelpDocs/2601B-PULSE/19930.htm | 110 + WebHelpDocs/2601B-PULSE/19931.htm | 100 + WebHelpDocs/2601B-PULSE/2408.htm | 47 + WebHelpDocs/2601B-PULSE/2430.htm | 91 + WebHelpDocs/2601B-PULSE/2450_toc.xml | 0 .../2450commanddescription-details_lr.png | Bin 0 -> 2141 bytes .../2450description-example_lr.png | Bin 0 -> 7856 bytes .../2450tspdescription-alsosee_lr.png | Bin 0 -> 2006 bytes .../2450tspdescription-usage_lr.png | Bin 0 -> 11366 bytes WebHelpDocs/2601B-PULSE/24524.htm | 44 + WebHelpDocs/2601B-PULSE/2589.htm | 112 ++ WebHelpDocs/2601B-PULSE/25959.htm | 146 ++ WebHelpDocs/2601B-PULSE/2600A_toc.xml | 0 WebHelpDocs/2601B-PULSE/2600B_toc.xml | 0 ..._tsp_command_name_and_summary_table_lr.png | Bin 0 -> 19416 bytes ...weeptsptestscript_sweepilinmeasurev_lr.png | Bin 0 -> 4054 bytes ...weeptsptestscript_sweepilogmeasurev_lr.png | Bin 0 -> 4037 bytes ...weeptsptestscript_sweepvlinmeasurei_lr.png | Bin 0 -> 4036 bytes ...weeptsptestscript_sweepvlogmeasurei_lr.png | Bin 0 -> 3946 bytes .../2601B-PULSE_TSP_command_reference.htm | 42 + .../2601B-PULSE_command_reference.htm | 28 + ...1B-PULSE_introduction_to_TSP_operation.htm | 42 + .../2601b-pulse_display_modes_lr.png | Bin 0 -> 27124 bytes .../2601b-pulse_pulser_display_modes_lr.png | Bin 0 -> 26980 bytes WebHelpDocs/2601B-PULSE/2651A_toc.xml | 0 WebHelpDocs/2601B-PULSE/26898.htm | 227 +++ ...6xxas-901-01e_fourquadrantsofoperation.png | Bin 0 -> 35478 bytes WebHelpDocs/2601B-PULSE/29213.htm | 125 ++ WebHelpDocs/2601B-PULSE/29218.htm | 91 + WebHelpDocs/2601B-PULSE/29219.htm | 100 + WebHelpDocs/2601B-PULSE/29234.htm | 538 +++++ WebHelpDocs/2601B-PULSE/29255.htm | 326 +++ WebHelpDocs/2601B-PULSE/29272.htm | 44 + WebHelpDocs/2601B-PULSE/3240.htm | 45 + WebHelpDocs/2601B-PULSE/3247.htm | 48 + WebHelpDocs/2601B-PULSE/3249.htm | 65 + WebHelpDocs/2601B-PULSE/368.htm | 58 + WebHelpDocs/2601B-PULSE/3700S_toc.xml | 4 + .../2601B-PULSE/4200a_lc_next_button.png | Bin 0 -> 730 bytes .../2601B-PULSE/4200a_lc_previous_button.png | Bin 0 -> 1031 bytes WebHelpDocs/2601B-PULSE/46200.htm | 42 + WebHelpDocs/2601B-PULSE/492.htm | 98 + WebHelpDocs/2601B-PULSE/6500_toc.xml | 0 WebHelpDocs/2601B-PULSE/6510_toc.xml | 0 WebHelpDocs/2601B-PULSE/66559.htm | 99 + WebHelpDocs/2601B-PULSE/66560.htm | 90 + WebHelpDocs/2601B-PULSE/66566.htm | 105 + WebHelpDocs/2601B-PULSE/72522.htm | 49 + WebHelpDocs/2601B-PULSE/77377.htm | 64 + WebHelpDocs/2601B-PULSE/77502.htm | 61 + WebHelpDocs/2601B-PULSE/80596.htm | 140 ++ WebHelpDocs/2601B-PULSE/91672.htm | 95 + WebHelpDocs/2601B-PULSE/91673.htm | 104 + WebHelpDocs/2601B-PULSE/91674.htm | 96 + WebHelpDocs/2601B-PULSE/91675.htm | 99 + WebHelpDocs/2601B-PULSE/91676.htm | 96 + WebHelpDocs/2601B-PULSE/91677.htm | 164 ++ WebHelpDocs/2601B-PULSE/91678.htm | 97 + WebHelpDocs/2601B-PULSE/91702.htm | 43 + WebHelpDocs/2601B-PULSE/91895.htm | 132 ++ WebHelpDocs/2601B-PULSE/91897.htm | 125 ++ WebHelpDocs/2601B-PULSE/91898.htm | 126 ++ WebHelpDocs/2601B-PULSE/91979.htm | 43 + WebHelpDocs/2601B-PULSE/92073.htm | 92 + WebHelpDocs/2601B-PULSE/92074.htm | 93 + WebHelpDocs/2601B-PULSE/92075.htm | 92 + WebHelpDocs/2601B-PULSE/92127.htm | 47 + WebHelpDocs/2601B-PULSE/92241.htm | 101 + WebHelpDocs/2601B-PULSE/92282.htm | 94 + WebHelpDocs/2601B-PULSE/92304.htm | 44 + WebHelpDocs/2601B-PULSE/92312.htm | 106 + WebHelpDocs/2601B-PULSE/92317.htm | 110 + WebHelpDocs/2601B-PULSE/92325.htm | 171 ++ WebHelpDocs/2601B-PULSE/92333.htm | 103 + WebHelpDocs/2601B-PULSE/92343.htm | 94 + WebHelpDocs/2601B-PULSE/92358.htm | 99 + WebHelpDocs/2601B-PULSE/92359.htm | 105 + WebHelpDocs/2601B-PULSE/92361.htm | 106 + WebHelpDocs/2601B-PULSE/92390.htm | 547 +++++ WebHelpDocs/2601B-PULSE/92460.htm | 60 + WebHelpDocs/2601B-PULSE/92517.htm | 91 + WebHelpDocs/2601B-PULSE/92519.htm | 99 + WebHelpDocs/2601B-PULSE/92520.htm | 99 + WebHelpDocs/2601B-PULSE/92521.htm | 102 + WebHelpDocs/2601B-PULSE/92539.htm | 99 + WebHelpDocs/2601B-PULSE/92540.htm | 99 + WebHelpDocs/2601B-PULSE/92659.htm | 280 +++ WebHelpDocs/2601B-PULSE/92660.htm | 287 +++ WebHelpDocs/2601B-PULSE/92661.htm | 292 +++ WebHelpDocs/2601B-PULSE/92663.htm | 337 ++++ WebHelpDocs/2601B-PULSE/92664.htm | 325 +++ WebHelpDocs/2601B-PULSE/92667.htm | 91 + WebHelpDocs/2601B-PULSE/92683.htm | 521 +++++ WebHelpDocs/2601B-PULSE/92690.htm | 528 +++++ WebHelpDocs/2601B-PULSE/92697.htm | 509 +++++ WebHelpDocs/2601B-PULSE/92702.htm | 234 +++ WebHelpDocs/2601B-PULSE/92703.htm | 92 + WebHelpDocs/2601B-PULSE/92706.htm | 110 + WebHelpDocs/2601B-PULSE/92710.htm | 60 + WebHelpDocs/2601B-PULSE/92712.htm | 112 ++ WebHelpDocs/2601B-PULSE/92713.htm | 94 + WebHelpDocs/2601B-PULSE/92715.htm | 101 + WebHelpDocs/2601B-PULSE/92743.htm | 206 ++ WebHelpDocs/2601B-PULSE/92979.htm | 107 + WebHelpDocs/2601B-PULSE/92990.htm | 101 + WebHelpDocs/2601B-PULSE/92991.htm | 100 + WebHelpDocs/2601B-PULSE/92998.htm | 196 ++ WebHelpDocs/2601B-PULSE/92999.htm | 194 ++ WebHelpDocs/2601B-PULSE/93000.htm | 195 ++ WebHelpDocs/2601B-PULSE/93010.htm | 206 ++ WebHelpDocs/2601B-PULSE/93012.htm | 206 ++ WebHelpDocs/2601B-PULSE/93014.htm | 206 ++ WebHelpDocs/2601B-PULSE/93016.htm | 538 +++++ WebHelpDocs/2601B-PULSE/93017.htm | 207 ++ WebHelpDocs/2601B-PULSE/93035.htm | 195 ++ WebHelpDocs/2601B-PULSE/93037.htm | 534 +++++ WebHelpDocs/2601B-PULSE/93038.htm | 195 ++ WebHelpDocs/2601B-PULSE/93039.htm | 207 ++ WebHelpDocs/2601B-PULSE/93040.htm | 208 ++ WebHelpDocs/2601B-PULSE/93041.htm | 207 ++ WebHelpDocs/2601B-PULSE/93042.htm | 100 + WebHelpDocs/2601B-PULSE/93060.htm | 103 + WebHelpDocs/2601B-PULSE/93150.htm | 123 ++ WebHelpDocs/2601B-PULSE/93152.htm | 133 ++ WebHelpDocs/2601B-PULSE/93173.htm | 139 ++ WebHelpDocs/2601B-PULSE/93175.htm | 101 + WebHelpDocs/2601B-PULSE/93187.htm | 1772 +++++++++++++++++ WebHelpDocs/2601B-PULSE/93207.htm | 104 + WebHelpDocs/2601B-PULSE/93212.htm | 44 + WebHelpDocs/2601B-PULSE/93213.htm | 42 + WebHelpDocs/2601B-PULSE/93214.htm | 44 + WebHelpDocs/2601B-PULSE/93219.htm | 44 + WebHelpDocs/2601B-PULSE/AfterPublish.bat | 19 + .../2601B-PULSE/EclipseHelpTemplate.html | Bin 0 -> 1476 bytes .../Model 2601B-PULSE help files.hs | 25 + WebHelpDocs/2601B-PULSE/OracleToEclipse.exe | Bin 0 -> 16384 bytes WebHelpDocs/2601B-PULSE/OracleToEclipse.xslt | 28 + .../caution_large_no_exclaim_lr.png | Bin 0 -> 943 bytes WebHelpDocs/2601B-PULSE/contents1.gif | Bin 0 -> 1057 bytes WebHelpDocs/2601B-PULSE/contents2.gif | Bin 0 -> 1058 bytes WebHelpDocs/2601B-PULSE/contents3.gif | Bin 0 -> 1058 bytes WebHelpDocs/2601B-PULSE/dhtml_search.htm | 13 + WebHelpDocs/2601B-PULSE/dhtml_search.js | 628 ++++++ .../exampleinstrumentcommanddescription.png | Bin 0 -> 17356 bytes WebHelpDocs/2601B-PULSE/index1.gif | Bin 0 -> 1008 bytes WebHelpDocs/2601B-PULSE/index2.gif | Bin 0 -> 1008 bytes WebHelpDocs/2601B-PULSE/index3.gif | Bin 0 -> 1008 bytes WebHelpDocs/2601B-PULSE/index_template.htm | 24 + WebHelpDocs/2601B-PULSE/jh_index.xml | 9 + WebHelpDocs/2601B-PULSE/jh_project.hs | 40 + WebHelpDocs/2601B-PULSE/jh_toc.xml | 4 + WebHelpDocs/2601B-PULSE/map.jhm | 571 ++++++ WebHelpDocs/2601B-PULSE/notesmall_lr.png | Bin 0 -> 369 bytes WebHelpDocs/2601B-PULSE/nwvector.png | Bin 0 -> 848 bytes WebHelpDocs/2601B-PULSE/search.idx | Bin 0 -> 328244 bytes WebHelpDocs/2601B-PULSE/search1.gif | Bin 0 -> 1043 bytes WebHelpDocs/2601B-PULSE/search2.gif | Bin 0 -> 1041 bytes WebHelpDocs/2601B-PULSE/search3.gif | Bin 0 -> 1052 bytes WebHelpDocs/2601B-PULSE/stylesheet.css | 1450 ++++++++++++++ WebHelpDocs/2601B-PULSE/tab_index.htm | 30 + WebHelpDocs/2601B-PULSE/tab_search.htm | 30 + WebHelpDocs/2601B-PULSE/tab_toc.htm | 30 + WebHelpDocs/2601B-PULSE/tail.gif | Bin 0 -> 926 bytes WebHelpDocs/2601B-PULSE/toc.hhc | 15 + WebHelpDocs/2601B-PULSE/toc.xml | 581 ++++++ WebHelpDocs/2601B-PULSE/toc_template.htm | 24 + 617 files changed, 72515 insertions(+) create mode 100644 WebHelpDocs/2601B-PULSE/10835.htm create mode 100644 WebHelpDocs/2601B-PULSE/10905.htm create mode 100644 WebHelpDocs/2601B-PULSE/11274.htm create mode 100644 WebHelpDocs/2601B-PULSE/11382.htm create mode 100644 WebHelpDocs/2601B-PULSE/11440.htm create mode 100644 WebHelpDocs/2601B-PULSE/11500.htm create mode 100644 WebHelpDocs/2601B-PULSE/11532.htm create mode 100644 WebHelpDocs/2601B-PULSE/11584.htm create mode 100644 WebHelpDocs/2601B-PULSE/11613.htm create mode 100644 WebHelpDocs/2601B-PULSE/11655.htm create mode 100644 WebHelpDocs/2601B-PULSE/11848.htm create mode 100644 WebHelpDocs/2601B-PULSE/11993.htm create mode 100644 WebHelpDocs/2601B-PULSE/11998.htm create mode 100644 WebHelpDocs/2601B-PULSE/12001.htm create mode 100644 WebHelpDocs/2601B-PULSE/12044.htm create mode 100644 WebHelpDocs/2601B-PULSE/12125.htm create mode 100644 WebHelpDocs/2601B-PULSE/12137.htm create mode 100644 WebHelpDocs/2601B-PULSE/12175.htm create mode 100644 WebHelpDocs/2601B-PULSE/12177.htm create mode 100644 WebHelpDocs/2601B-PULSE/12181.htm create mode 100644 WebHelpDocs/2601B-PULSE/12184.htm create mode 100644 WebHelpDocs/2601B-PULSE/12190.htm create mode 100644 WebHelpDocs/2601B-PULSE/12192.htm create mode 100644 WebHelpDocs/2601B-PULSE/12194.htm create mode 100644 WebHelpDocs/2601B-PULSE/12259.htm create mode 100644 WebHelpDocs/2601B-PULSE/12451.htm create mode 100644 WebHelpDocs/2601B-PULSE/12571.htm create mode 100644 WebHelpDocs/2601B-PULSE/12893.htm create mode 100644 WebHelpDocs/2601B-PULSE/12911.htm create mode 100644 WebHelpDocs/2601B-PULSE/12913.htm create mode 100644 WebHelpDocs/2601B-PULSE/12914.htm create mode 100644 WebHelpDocs/2601B-PULSE/12950.htm create mode 100644 WebHelpDocs/2601B-PULSE/12951.htm create mode 100644 WebHelpDocs/2601B-PULSE/12953.htm create mode 100644 WebHelpDocs/2601B-PULSE/12954.htm create mode 100644 WebHelpDocs/2601B-PULSE/12955.htm create mode 100644 WebHelpDocs/2601B-PULSE/12957.htm create mode 100644 WebHelpDocs/2601B-PULSE/12958.htm create mode 100644 WebHelpDocs/2601B-PULSE/12959.htm create mode 100644 WebHelpDocs/2601B-PULSE/13401.htm create mode 100644 WebHelpDocs/2601B-PULSE/13605.htm create mode 100644 WebHelpDocs/2601B-PULSE/13629.htm create mode 100644 WebHelpDocs/2601B-PULSE/13811.htm create mode 100644 WebHelpDocs/2601B-PULSE/13933.htm create mode 100644 WebHelpDocs/2601B-PULSE/13943.htm create mode 100644 WebHelpDocs/2601B-PULSE/13949.htm create mode 100644 WebHelpDocs/2601B-PULSE/13986.htm create mode 100644 WebHelpDocs/2601B-PULSE/13987.htm create mode 100644 WebHelpDocs/2601B-PULSE/13988.htm create mode 100644 WebHelpDocs/2601B-PULSE/13989.htm create mode 100644 WebHelpDocs/2601B-PULSE/13990.htm create mode 100644 WebHelpDocs/2601B-PULSE/14072.htm create mode 100644 WebHelpDocs/2601B-PULSE/14073.htm create mode 100644 WebHelpDocs/2601B-PULSE/14074.htm create mode 100644 WebHelpDocs/2601B-PULSE/14076.htm create mode 100644 WebHelpDocs/2601B-PULSE/14077.htm create mode 100644 WebHelpDocs/2601B-PULSE/14078.htm create mode 100644 WebHelpDocs/2601B-PULSE/14079.htm create mode 100644 WebHelpDocs/2601B-PULSE/14080.htm create mode 100644 WebHelpDocs/2601B-PULSE/14081.htm create mode 100644 WebHelpDocs/2601B-PULSE/14082.htm create mode 100644 WebHelpDocs/2601B-PULSE/14084.htm create mode 100644 WebHelpDocs/2601B-PULSE/14085.htm create mode 100644 WebHelpDocs/2601B-PULSE/14086.htm create mode 100644 WebHelpDocs/2601B-PULSE/14089.htm create mode 100644 WebHelpDocs/2601B-PULSE/14090.htm create mode 100644 WebHelpDocs/2601B-PULSE/14126.htm create mode 100644 WebHelpDocs/2601B-PULSE/14127.htm create mode 100644 WebHelpDocs/2601B-PULSE/14129.htm create mode 100644 WebHelpDocs/2601B-PULSE/14435.htm create mode 100644 WebHelpDocs/2601B-PULSE/14632.htm create mode 100644 WebHelpDocs/2601B-PULSE/14634.htm create mode 100644 WebHelpDocs/2601B-PULSE/14635.htm create mode 100644 WebHelpDocs/2601B-PULSE/14636.htm create mode 100644 WebHelpDocs/2601B-PULSE/14637.htm create mode 100644 WebHelpDocs/2601B-PULSE/14638.htm create mode 100644 WebHelpDocs/2601B-PULSE/14639.htm create mode 100644 WebHelpDocs/2601B-PULSE/14640.htm create mode 100644 WebHelpDocs/2601B-PULSE/14641.htm create mode 100644 WebHelpDocs/2601B-PULSE/14642.htm create mode 100644 WebHelpDocs/2601B-PULSE/14653.htm create mode 100644 WebHelpDocs/2601B-PULSE/14654.htm create mode 100644 WebHelpDocs/2601B-PULSE/14655.htm create mode 100644 WebHelpDocs/2601B-PULSE/14656.htm create mode 100644 WebHelpDocs/2601B-PULSE/14657.htm create mode 100644 WebHelpDocs/2601B-PULSE/14658.htm create mode 100644 WebHelpDocs/2601B-PULSE/14668.htm create mode 100644 WebHelpDocs/2601B-PULSE/14669.htm create mode 100644 WebHelpDocs/2601B-PULSE/14670.htm create mode 100644 WebHelpDocs/2601B-PULSE/14671.htm create mode 100644 WebHelpDocs/2601B-PULSE/14672.htm create mode 100644 WebHelpDocs/2601B-PULSE/14674.htm create mode 100644 WebHelpDocs/2601B-PULSE/14675.htm create mode 100644 WebHelpDocs/2601B-PULSE/14677.htm create mode 100644 WebHelpDocs/2601B-PULSE/14679.htm create mode 100644 WebHelpDocs/2601B-PULSE/14680.htm create mode 100644 WebHelpDocs/2601B-PULSE/14681.htm create mode 100644 WebHelpDocs/2601B-PULSE/14682.htm create mode 100644 WebHelpDocs/2601B-PULSE/14699.htm create mode 100644 WebHelpDocs/2601B-PULSE/14700.htm create mode 100644 WebHelpDocs/2601B-PULSE/14702.htm create mode 100644 WebHelpDocs/2601B-PULSE/14703.htm create mode 100644 WebHelpDocs/2601B-PULSE/14705.htm create mode 100644 WebHelpDocs/2601B-PULSE/14706.htm create mode 100644 WebHelpDocs/2601B-PULSE/14707.htm create mode 100644 WebHelpDocs/2601B-PULSE/14708.htm create mode 100644 WebHelpDocs/2601B-PULSE/14709.htm create mode 100644 WebHelpDocs/2601B-PULSE/14711.htm create mode 100644 WebHelpDocs/2601B-PULSE/14712.htm create mode 100644 WebHelpDocs/2601B-PULSE/14715.htm create mode 100644 WebHelpDocs/2601B-PULSE/14716.htm create mode 100644 WebHelpDocs/2601B-PULSE/14717.htm create mode 100644 WebHelpDocs/2601B-PULSE/14719.htm create mode 100644 WebHelpDocs/2601B-PULSE/14739.htm create mode 100644 WebHelpDocs/2601B-PULSE/14740.htm create mode 100644 WebHelpDocs/2601B-PULSE/14748.htm create mode 100644 WebHelpDocs/2601B-PULSE/14749.htm create mode 100644 WebHelpDocs/2601B-PULSE/14750.htm create mode 100644 WebHelpDocs/2601B-PULSE/14756.htm create mode 100644 WebHelpDocs/2601B-PULSE/14757.htm create mode 100644 WebHelpDocs/2601B-PULSE/14758.htm create mode 100644 WebHelpDocs/2601B-PULSE/14759.htm create mode 100644 WebHelpDocs/2601B-PULSE/14760.htm create mode 100644 WebHelpDocs/2601B-PULSE/14761.htm create mode 100644 WebHelpDocs/2601B-PULSE/14769.htm create mode 100644 WebHelpDocs/2601B-PULSE/14771.htm create mode 100644 WebHelpDocs/2601B-PULSE/14772.htm create mode 100644 WebHelpDocs/2601B-PULSE/14786.htm create mode 100644 WebHelpDocs/2601B-PULSE/14787.htm create mode 100644 WebHelpDocs/2601B-PULSE/14788.htm create mode 100644 WebHelpDocs/2601B-PULSE/14789.htm create mode 100644 WebHelpDocs/2601B-PULSE/14795.htm create mode 100644 WebHelpDocs/2601B-PULSE/14797.htm create mode 100644 WebHelpDocs/2601B-PULSE/14801.htm create mode 100644 WebHelpDocs/2601B-PULSE/14803.htm create mode 100644 WebHelpDocs/2601B-PULSE/14808.htm create mode 100644 WebHelpDocs/2601B-PULSE/14810.htm create mode 100644 WebHelpDocs/2601B-PULSE/14811.htm create mode 100644 WebHelpDocs/2601B-PULSE/14812.htm create mode 100644 WebHelpDocs/2601B-PULSE/14814.htm create mode 100644 WebHelpDocs/2601B-PULSE/14815.htm create mode 100644 WebHelpDocs/2601B-PULSE/14824.htm create mode 100644 WebHelpDocs/2601B-PULSE/14859.htm create mode 100644 WebHelpDocs/2601B-PULSE/14860.htm create mode 100644 WebHelpDocs/2601B-PULSE/14868.htm create mode 100644 WebHelpDocs/2601B-PULSE/14870.htm create mode 100644 WebHelpDocs/2601B-PULSE/14872.htm create mode 100644 WebHelpDocs/2601B-PULSE/14873.htm create mode 100644 WebHelpDocs/2601B-PULSE/14874.htm create mode 100644 WebHelpDocs/2601B-PULSE/14875.htm create mode 100644 WebHelpDocs/2601B-PULSE/14877.htm create mode 100644 WebHelpDocs/2601B-PULSE/14890.htm create mode 100644 WebHelpDocs/2601B-PULSE/14891.htm create mode 100644 WebHelpDocs/2601B-PULSE/14892.htm create mode 100644 WebHelpDocs/2601B-PULSE/14893.htm create mode 100644 WebHelpDocs/2601B-PULSE/14894.htm create mode 100644 WebHelpDocs/2601B-PULSE/14895.htm create mode 100644 WebHelpDocs/2601B-PULSE/14896.htm create mode 100644 WebHelpDocs/2601B-PULSE/14897.htm create mode 100644 WebHelpDocs/2601B-PULSE/14898.htm create mode 100644 WebHelpDocs/2601B-PULSE/14899.htm create mode 100644 WebHelpDocs/2601B-PULSE/14900.htm create mode 100644 WebHelpDocs/2601B-PULSE/14902.htm create mode 100644 WebHelpDocs/2601B-PULSE/14903.htm create mode 100644 WebHelpDocs/2601B-PULSE/14904.htm create mode 100644 WebHelpDocs/2601B-PULSE/14905.htm create mode 100644 WebHelpDocs/2601B-PULSE/14906.htm create mode 100644 WebHelpDocs/2601B-PULSE/14907.htm create mode 100644 WebHelpDocs/2601B-PULSE/14908.htm create mode 100644 WebHelpDocs/2601B-PULSE/14909.htm create mode 100644 WebHelpDocs/2601B-PULSE/14910.htm create mode 100644 WebHelpDocs/2601B-PULSE/14911.htm create mode 100644 WebHelpDocs/2601B-PULSE/14912.htm create mode 100644 WebHelpDocs/2601B-PULSE/14913.htm create mode 100644 WebHelpDocs/2601B-PULSE/14914.htm create mode 100644 WebHelpDocs/2601B-PULSE/14915.htm create mode 100644 WebHelpDocs/2601B-PULSE/14916.htm create mode 100644 WebHelpDocs/2601B-PULSE/14917.htm create mode 100644 WebHelpDocs/2601B-PULSE/14918.htm create mode 100644 WebHelpDocs/2601B-PULSE/14919.htm create mode 100644 WebHelpDocs/2601B-PULSE/14920.htm create mode 100644 WebHelpDocs/2601B-PULSE/14921.htm create mode 100644 WebHelpDocs/2601B-PULSE/14922.htm create mode 100644 WebHelpDocs/2601B-PULSE/14923.htm create mode 100644 WebHelpDocs/2601B-PULSE/14924.htm create mode 100644 WebHelpDocs/2601B-PULSE/14925.htm create mode 100644 WebHelpDocs/2601B-PULSE/14926.htm create mode 100644 WebHelpDocs/2601B-PULSE/14927.htm create mode 100644 WebHelpDocs/2601B-PULSE/14928.htm create mode 100644 WebHelpDocs/2601B-PULSE/14929.htm create mode 100644 WebHelpDocs/2601B-PULSE/14930.htm create mode 100644 WebHelpDocs/2601B-PULSE/14931.htm create mode 100644 WebHelpDocs/2601B-PULSE/14933.htm create mode 100644 WebHelpDocs/2601B-PULSE/15007.htm create mode 100644 WebHelpDocs/2601B-PULSE/15008.htm create mode 100644 WebHelpDocs/2601B-PULSE/15010.htm create mode 100644 WebHelpDocs/2601B-PULSE/15011.htm create mode 100644 WebHelpDocs/2601B-PULSE/15012.htm create mode 100644 WebHelpDocs/2601B-PULSE/15014.htm create mode 100644 WebHelpDocs/2601B-PULSE/15015.htm create mode 100644 WebHelpDocs/2601B-PULSE/15016.htm create mode 100644 WebHelpDocs/2601B-PULSE/15017.htm create mode 100644 WebHelpDocs/2601B-PULSE/15018.htm create mode 100644 WebHelpDocs/2601B-PULSE/15019.htm create mode 100644 WebHelpDocs/2601B-PULSE/15020.htm create mode 100644 WebHelpDocs/2601B-PULSE/15021.htm create mode 100644 WebHelpDocs/2601B-PULSE/15022.htm create mode 100644 WebHelpDocs/2601B-PULSE/15041.htm create mode 100644 WebHelpDocs/2601B-PULSE/15042.htm create mode 100644 WebHelpDocs/2601B-PULSE/15050.htm create mode 100644 WebHelpDocs/2601B-PULSE/15054.htm create mode 100644 WebHelpDocs/2601B-PULSE/15058.htm create mode 100644 WebHelpDocs/2601B-PULSE/15061.htm create mode 100644 WebHelpDocs/2601B-PULSE/15062.htm create mode 100644 WebHelpDocs/2601B-PULSE/15063.htm create mode 100644 WebHelpDocs/2601B-PULSE/15064.htm create mode 100644 WebHelpDocs/2601B-PULSE/15067.htm create mode 100644 WebHelpDocs/2601B-PULSE/15068.htm create mode 100644 WebHelpDocs/2601B-PULSE/15069.htm create mode 100644 WebHelpDocs/2601B-PULSE/15070.htm create mode 100644 WebHelpDocs/2601B-PULSE/15071.htm create mode 100644 WebHelpDocs/2601B-PULSE/15072.htm create mode 100644 WebHelpDocs/2601B-PULSE/15073.htm create mode 100644 WebHelpDocs/2601B-PULSE/15081.htm create mode 100644 WebHelpDocs/2601B-PULSE/15083.htm create mode 100644 WebHelpDocs/2601B-PULSE/15088.htm create mode 100644 WebHelpDocs/2601B-PULSE/15089.htm create mode 100644 WebHelpDocs/2601B-PULSE/15090.htm create mode 100644 WebHelpDocs/2601B-PULSE/15091.htm create mode 100644 WebHelpDocs/2601B-PULSE/15092.htm create mode 100644 WebHelpDocs/2601B-PULSE/15093.htm create mode 100644 WebHelpDocs/2601B-PULSE/15094.htm create mode 100644 WebHelpDocs/2601B-PULSE/15095.htm create mode 100644 WebHelpDocs/2601B-PULSE/15096.htm create mode 100644 WebHelpDocs/2601B-PULSE/15098.htm create mode 100644 WebHelpDocs/2601B-PULSE/15099.htm create mode 100644 WebHelpDocs/2601B-PULSE/15100.htm create mode 100644 WebHelpDocs/2601B-PULSE/15105.htm create mode 100644 WebHelpDocs/2601B-PULSE/15107.htm create mode 100644 WebHelpDocs/2601B-PULSE/15109.htm create mode 100644 WebHelpDocs/2601B-PULSE/15112.htm create mode 100644 WebHelpDocs/2601B-PULSE/15113.htm create mode 100644 WebHelpDocs/2601B-PULSE/15114.htm create mode 100644 WebHelpDocs/2601B-PULSE/15116.htm create mode 100644 WebHelpDocs/2601B-PULSE/15120.htm create mode 100644 WebHelpDocs/2601B-PULSE/15122.htm create mode 100644 WebHelpDocs/2601B-PULSE/15123.htm create mode 100644 WebHelpDocs/2601B-PULSE/15124.htm create mode 100644 WebHelpDocs/2601B-PULSE/15127.htm create mode 100644 WebHelpDocs/2601B-PULSE/15128.htm create mode 100644 WebHelpDocs/2601B-PULSE/15129.htm create mode 100644 WebHelpDocs/2601B-PULSE/15130.htm create mode 100644 WebHelpDocs/2601B-PULSE/15131.htm create mode 100644 WebHelpDocs/2601B-PULSE/15132.htm create mode 100644 WebHelpDocs/2601B-PULSE/15133.htm create mode 100644 WebHelpDocs/2601B-PULSE/15134.htm create mode 100644 WebHelpDocs/2601B-PULSE/15135.htm create mode 100644 WebHelpDocs/2601B-PULSE/15136.htm create mode 100644 WebHelpDocs/2601B-PULSE/15137.htm create mode 100644 WebHelpDocs/2601B-PULSE/15139.htm create mode 100644 WebHelpDocs/2601B-PULSE/15141.htm create mode 100644 WebHelpDocs/2601B-PULSE/15142.htm create mode 100644 WebHelpDocs/2601B-PULSE/15143.htm create mode 100644 WebHelpDocs/2601B-PULSE/15144.htm create mode 100644 WebHelpDocs/2601B-PULSE/15145.htm create mode 100644 WebHelpDocs/2601B-PULSE/15149.htm create mode 100644 WebHelpDocs/2601B-PULSE/15151.htm create mode 100644 WebHelpDocs/2601B-PULSE/15155.htm create mode 100644 WebHelpDocs/2601B-PULSE/15156.htm create mode 100644 WebHelpDocs/2601B-PULSE/15157.htm create mode 100644 WebHelpDocs/2601B-PULSE/15158.htm create mode 100644 WebHelpDocs/2601B-PULSE/15159.htm create mode 100644 WebHelpDocs/2601B-PULSE/15160.htm create mode 100644 WebHelpDocs/2601B-PULSE/15161.htm create mode 100644 WebHelpDocs/2601B-PULSE/15163.htm create mode 100644 WebHelpDocs/2601B-PULSE/15165.htm create mode 100644 WebHelpDocs/2601B-PULSE/15166.htm create mode 100644 WebHelpDocs/2601B-PULSE/15167.htm create mode 100644 WebHelpDocs/2601B-PULSE/15168.htm create mode 100644 WebHelpDocs/2601B-PULSE/15169.htm create mode 100644 WebHelpDocs/2601B-PULSE/15170.htm create mode 100644 WebHelpDocs/2601B-PULSE/15171.htm create mode 100644 WebHelpDocs/2601B-PULSE/15172.htm create mode 100644 WebHelpDocs/2601B-PULSE/15173.htm create mode 100644 WebHelpDocs/2601B-PULSE/15174.htm create mode 100644 WebHelpDocs/2601B-PULSE/15175.htm create mode 100644 WebHelpDocs/2601B-PULSE/15176.htm create mode 100644 WebHelpDocs/2601B-PULSE/15177.htm create mode 100644 WebHelpDocs/2601B-PULSE/15178.htm create mode 100644 WebHelpDocs/2601B-PULSE/15179.htm create mode 100644 WebHelpDocs/2601B-PULSE/15180.htm create mode 100644 WebHelpDocs/2601B-PULSE/15181.htm create mode 100644 WebHelpDocs/2601B-PULSE/15182.htm create mode 100644 WebHelpDocs/2601B-PULSE/15183.htm create mode 100644 WebHelpDocs/2601B-PULSE/15184.htm create mode 100644 WebHelpDocs/2601B-PULSE/15280.htm create mode 100644 WebHelpDocs/2601B-PULSE/15281.htm create mode 100644 WebHelpDocs/2601B-PULSE/15282.htm create mode 100644 WebHelpDocs/2601B-PULSE/15285.htm create mode 100644 WebHelpDocs/2601B-PULSE/15286.htm create mode 100644 WebHelpDocs/2601B-PULSE/15287.htm create mode 100644 WebHelpDocs/2601B-PULSE/15288.htm create mode 100644 WebHelpDocs/2601B-PULSE/15289.htm create mode 100644 WebHelpDocs/2601B-PULSE/15290.htm create mode 100644 WebHelpDocs/2601B-PULSE/15291.htm create mode 100644 WebHelpDocs/2601B-PULSE/15292.htm create mode 100644 WebHelpDocs/2601B-PULSE/15293.htm create mode 100644 WebHelpDocs/2601B-PULSE/15294.htm create mode 100644 WebHelpDocs/2601B-PULSE/15295.htm create mode 100644 WebHelpDocs/2601B-PULSE/15296.htm create mode 100644 WebHelpDocs/2601B-PULSE/15297.htm create mode 100644 WebHelpDocs/2601B-PULSE/15298.htm create mode 100644 WebHelpDocs/2601B-PULSE/15300.htm create mode 100644 WebHelpDocs/2601B-PULSE/15301.htm create mode 100644 WebHelpDocs/2601B-PULSE/15302.htm create mode 100644 WebHelpDocs/2601B-PULSE/15424.htm create mode 100644 WebHelpDocs/2601B-PULSE/15785.htm create mode 100644 WebHelpDocs/2601B-PULSE/15786.htm create mode 100644 WebHelpDocs/2601B-PULSE/15787.htm create mode 100644 WebHelpDocs/2601B-PULSE/15788.htm create mode 100644 WebHelpDocs/2601B-PULSE/15790.htm create mode 100644 WebHelpDocs/2601B-PULSE/15791.htm create mode 100644 WebHelpDocs/2601B-PULSE/15792.htm create mode 100644 WebHelpDocs/2601B-PULSE/15793.htm create mode 100644 WebHelpDocs/2601B-PULSE/15794.htm create mode 100644 WebHelpDocs/2601B-PULSE/15795.htm create mode 100644 WebHelpDocs/2601B-PULSE/15796.htm create mode 100644 WebHelpDocs/2601B-PULSE/15797.htm create mode 100644 WebHelpDocs/2601B-PULSE/15798.htm create mode 100644 WebHelpDocs/2601B-PULSE/15800.htm create mode 100644 WebHelpDocs/2601B-PULSE/15801.htm create mode 100644 WebHelpDocs/2601B-PULSE/15820.htm create mode 100644 WebHelpDocs/2601B-PULSE/15830.htm create mode 100644 WebHelpDocs/2601B-PULSE/15831.htm create mode 100644 WebHelpDocs/2601B-PULSE/15833.htm create mode 100644 WebHelpDocs/2601B-PULSE/15836.htm create mode 100644 WebHelpDocs/2601B-PULSE/15837.htm create mode 100644 WebHelpDocs/2601B-PULSE/15838.htm create mode 100644 WebHelpDocs/2601B-PULSE/15839.htm create mode 100644 WebHelpDocs/2601B-PULSE/15840.htm create mode 100644 WebHelpDocs/2601B-PULSE/15841.htm create mode 100644 WebHelpDocs/2601B-PULSE/15842.htm create mode 100644 WebHelpDocs/2601B-PULSE/15844.htm create mode 100644 WebHelpDocs/2601B-PULSE/15845.htm create mode 100644 WebHelpDocs/2601B-PULSE/15846.htm create mode 100644 WebHelpDocs/2601B-PULSE/15847.htm create mode 100644 WebHelpDocs/2601B-PULSE/15849.htm create mode 100644 WebHelpDocs/2601B-PULSE/15852.htm create mode 100644 WebHelpDocs/2601B-PULSE/15861.htm create mode 100644 WebHelpDocs/2601B-PULSE/15862.htm create mode 100644 WebHelpDocs/2601B-PULSE/15863.htm create mode 100644 WebHelpDocs/2601B-PULSE/15864.htm create mode 100644 WebHelpDocs/2601B-PULSE/15865.htm create mode 100644 WebHelpDocs/2601B-PULSE/15866.htm create mode 100644 WebHelpDocs/2601B-PULSE/15867.htm create mode 100644 WebHelpDocs/2601B-PULSE/15965.htm create mode 100644 WebHelpDocs/2601B-PULSE/16803.htm create mode 100644 WebHelpDocs/2601B-PULSE/16805.htm create mode 100644 WebHelpDocs/2601B-PULSE/16851.htm create mode 100644 WebHelpDocs/2601B-PULSE/16852.htm create mode 100644 WebHelpDocs/2601B-PULSE/16853.htm create mode 100644 WebHelpDocs/2601B-PULSE/16856.htm create mode 100644 WebHelpDocs/2601B-PULSE/16862.htm create mode 100644 WebHelpDocs/2601B-PULSE/16863.htm create mode 100644 WebHelpDocs/2601B-PULSE/16867.htm create mode 100644 WebHelpDocs/2601B-PULSE/16978.htm create mode 100644 WebHelpDocs/2601B-PULSE/17029.htm create mode 100644 WebHelpDocs/2601B-PULSE/17030.htm create mode 100644 WebHelpDocs/2601B-PULSE/17040.htm create mode 100644 WebHelpDocs/2601B-PULSE/17109.htm create mode 100644 WebHelpDocs/2601B-PULSE/17112.htm create mode 100644 WebHelpDocs/2601B-PULSE/17268.htm create mode 100644 WebHelpDocs/2601B-PULSE/17630.htm create mode 100644 WebHelpDocs/2601B-PULSE/17645.htm create mode 100644 WebHelpDocs/2601B-PULSE/17666.htm create mode 100644 WebHelpDocs/2601B-PULSE/17668.htm create mode 100644 WebHelpDocs/2601B-PULSE/17669.htm create mode 100644 WebHelpDocs/2601B-PULSE/17679.htm create mode 100644 WebHelpDocs/2601B-PULSE/17682.htm create mode 100644 WebHelpDocs/2601B-PULSE/17684.htm create mode 100644 WebHelpDocs/2601B-PULSE/17688.htm create mode 100644 WebHelpDocs/2601B-PULSE/17691.htm create mode 100644 WebHelpDocs/2601B-PULSE/17719.htm create mode 100644 WebHelpDocs/2601B-PULSE/17785.htm create mode 100644 WebHelpDocs/2601B-PULSE/17789.htm create mode 100644 WebHelpDocs/2601B-PULSE/17852.htm create mode 100644 WebHelpDocs/2601B-PULSE/17853.htm create mode 100644 WebHelpDocs/2601B-PULSE/17854.htm create mode 100644 WebHelpDocs/2601B-PULSE/17855.htm create mode 100644 WebHelpDocs/2601B-PULSE/17856.htm create mode 100644 WebHelpDocs/2601B-PULSE/17857.htm create mode 100644 WebHelpDocs/2601B-PULSE/17860.htm create mode 100644 WebHelpDocs/2601B-PULSE/18551.htm create mode 100644 WebHelpDocs/2601B-PULSE/18552.htm create mode 100644 WebHelpDocs/2601B-PULSE/18554.htm create mode 100644 WebHelpDocs/2601B-PULSE/18556.htm create mode 100644 WebHelpDocs/2601B-PULSE/18560.htm create mode 100644 WebHelpDocs/2601B-PULSE/18832.htm create mode 100644 WebHelpDocs/2601B-PULSE/18833.htm create mode 100644 WebHelpDocs/2601B-PULSE/18841.htm create mode 100644 WebHelpDocs/2601B-PULSE/19138.htm create mode 100644 WebHelpDocs/2601B-PULSE/19382.htm create mode 100644 WebHelpDocs/2601B-PULSE/19389.htm create mode 100644 WebHelpDocs/2601B-PULSE/19423.htm create mode 100644 WebHelpDocs/2601B-PULSE/19424.htm create mode 100644 WebHelpDocs/2601B-PULSE/19425.htm create mode 100644 WebHelpDocs/2601B-PULSE/19432.htm create mode 100644 WebHelpDocs/2601B-PULSE/19516.htm create mode 100644 WebHelpDocs/2601B-PULSE/19536.htm create mode 100644 WebHelpDocs/2601B-PULSE/19550.htm create mode 100644 WebHelpDocs/2601B-PULSE/19551.htm create mode 100644 WebHelpDocs/2601B-PULSE/19552.htm create mode 100644 WebHelpDocs/2601B-PULSE/19553.htm create mode 100644 WebHelpDocs/2601B-PULSE/19554.htm create mode 100644 WebHelpDocs/2601B-PULSE/19555.htm create mode 100644 WebHelpDocs/2601B-PULSE/19556.htm create mode 100644 WebHelpDocs/2601B-PULSE/19557.htm create mode 100644 WebHelpDocs/2601B-PULSE/19558.htm create mode 100644 WebHelpDocs/2601B-PULSE/19559.htm create mode 100644 WebHelpDocs/2601B-PULSE/19560.htm create mode 100644 WebHelpDocs/2601B-PULSE/19561.htm create mode 100644 WebHelpDocs/2601B-PULSE/19562.htm create mode 100644 WebHelpDocs/2601B-PULSE/19563.htm create mode 100644 WebHelpDocs/2601B-PULSE/19564.htm create mode 100644 WebHelpDocs/2601B-PULSE/19565.htm create mode 100644 WebHelpDocs/2601B-PULSE/19566.htm create mode 100644 WebHelpDocs/2601B-PULSE/19567.htm create mode 100644 WebHelpDocs/2601B-PULSE/19568.htm create mode 100644 WebHelpDocs/2601B-PULSE/19569.htm create mode 100644 WebHelpDocs/2601B-PULSE/19570.htm create mode 100644 WebHelpDocs/2601B-PULSE/19571.htm create mode 100644 WebHelpDocs/2601B-PULSE/19572.htm create mode 100644 WebHelpDocs/2601B-PULSE/19573.htm create mode 100644 WebHelpDocs/2601B-PULSE/19574.htm create mode 100644 WebHelpDocs/2601B-PULSE/19575.htm create mode 100644 WebHelpDocs/2601B-PULSE/19576.htm create mode 100644 WebHelpDocs/2601B-PULSE/19578.htm create mode 100644 WebHelpDocs/2601B-PULSE/19579.htm create mode 100644 WebHelpDocs/2601B-PULSE/19580.htm create mode 100644 WebHelpDocs/2601B-PULSE/19581.htm create mode 100644 WebHelpDocs/2601B-PULSE/19582.htm create mode 100644 WebHelpDocs/2601B-PULSE/19632.htm create mode 100644 WebHelpDocs/2601B-PULSE/19914.htm create mode 100644 WebHelpDocs/2601B-PULSE/19915.htm create mode 100644 WebHelpDocs/2601B-PULSE/19916.htm create mode 100644 WebHelpDocs/2601B-PULSE/19917.htm create mode 100644 WebHelpDocs/2601B-PULSE/19918.htm create mode 100644 WebHelpDocs/2601B-PULSE/19919.htm create mode 100644 WebHelpDocs/2601B-PULSE/19920.htm create mode 100644 WebHelpDocs/2601B-PULSE/19922.htm create mode 100644 WebHelpDocs/2601B-PULSE/19929.htm create mode 100644 WebHelpDocs/2601B-PULSE/19930.htm create mode 100644 WebHelpDocs/2601B-PULSE/19931.htm create mode 100644 WebHelpDocs/2601B-PULSE/2408.htm create mode 100644 WebHelpDocs/2601B-PULSE/2430.htm create mode 100644 WebHelpDocs/2601B-PULSE/2450_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/2450commanddescription-details_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2450description-example_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2450tspdescription-alsosee_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2450tspdescription-usage_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/24524.htm create mode 100644 WebHelpDocs/2601B-PULSE/2589.htm create mode 100644 WebHelpDocs/2601B-PULSE/25959.htm create mode 100644 WebHelpDocs/2601B-PULSE/2600A_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/2600B_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/2600_tsp_command_name_and_summary_table_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepilinmeasurev_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepilogmeasurev_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepvlinmeasurei_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepvlogmeasurei_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2601B-PULSE_TSP_command_reference.htm create mode 100644 WebHelpDocs/2601B-PULSE/2601B-PULSE_command_reference.htm create mode 100644 WebHelpDocs/2601B-PULSE/2601B-PULSE_introduction_to_TSP_operation.htm create mode 100644 WebHelpDocs/2601B-PULSE/2601b-pulse_display_modes_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2601b-pulse_pulser_display_modes_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/2651A_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/26898.htm create mode 100644 WebHelpDocs/2601B-PULSE/26xxas-901-01e_fourquadrantsofoperation.png create mode 100644 WebHelpDocs/2601B-PULSE/29213.htm create mode 100644 WebHelpDocs/2601B-PULSE/29218.htm create mode 100644 WebHelpDocs/2601B-PULSE/29219.htm create mode 100644 WebHelpDocs/2601B-PULSE/29234.htm create mode 100644 WebHelpDocs/2601B-PULSE/29255.htm create mode 100644 WebHelpDocs/2601B-PULSE/29272.htm create mode 100644 WebHelpDocs/2601B-PULSE/3240.htm create mode 100644 WebHelpDocs/2601B-PULSE/3247.htm create mode 100644 WebHelpDocs/2601B-PULSE/3249.htm create mode 100644 WebHelpDocs/2601B-PULSE/368.htm create mode 100644 WebHelpDocs/2601B-PULSE/3700S_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/4200a_lc_next_button.png create mode 100644 WebHelpDocs/2601B-PULSE/4200a_lc_previous_button.png create mode 100644 WebHelpDocs/2601B-PULSE/46200.htm create mode 100644 WebHelpDocs/2601B-PULSE/492.htm create mode 100644 WebHelpDocs/2601B-PULSE/6500_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/6510_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/66559.htm create mode 100644 WebHelpDocs/2601B-PULSE/66560.htm create mode 100644 WebHelpDocs/2601B-PULSE/66566.htm create mode 100644 WebHelpDocs/2601B-PULSE/72522.htm create mode 100644 WebHelpDocs/2601B-PULSE/77377.htm create mode 100644 WebHelpDocs/2601B-PULSE/77502.htm create mode 100644 WebHelpDocs/2601B-PULSE/80596.htm create mode 100644 WebHelpDocs/2601B-PULSE/91672.htm create mode 100644 WebHelpDocs/2601B-PULSE/91673.htm create mode 100644 WebHelpDocs/2601B-PULSE/91674.htm create mode 100644 WebHelpDocs/2601B-PULSE/91675.htm create mode 100644 WebHelpDocs/2601B-PULSE/91676.htm create mode 100644 WebHelpDocs/2601B-PULSE/91677.htm create mode 100644 WebHelpDocs/2601B-PULSE/91678.htm create mode 100644 WebHelpDocs/2601B-PULSE/91702.htm create mode 100644 WebHelpDocs/2601B-PULSE/91895.htm create mode 100644 WebHelpDocs/2601B-PULSE/91897.htm create mode 100644 WebHelpDocs/2601B-PULSE/91898.htm create mode 100644 WebHelpDocs/2601B-PULSE/91979.htm create mode 100644 WebHelpDocs/2601B-PULSE/92073.htm create mode 100644 WebHelpDocs/2601B-PULSE/92074.htm create mode 100644 WebHelpDocs/2601B-PULSE/92075.htm create mode 100644 WebHelpDocs/2601B-PULSE/92127.htm create mode 100644 WebHelpDocs/2601B-PULSE/92241.htm create mode 100644 WebHelpDocs/2601B-PULSE/92282.htm create mode 100644 WebHelpDocs/2601B-PULSE/92304.htm create mode 100644 WebHelpDocs/2601B-PULSE/92312.htm create mode 100644 WebHelpDocs/2601B-PULSE/92317.htm create mode 100644 WebHelpDocs/2601B-PULSE/92325.htm create mode 100644 WebHelpDocs/2601B-PULSE/92333.htm create mode 100644 WebHelpDocs/2601B-PULSE/92343.htm create mode 100644 WebHelpDocs/2601B-PULSE/92358.htm create mode 100644 WebHelpDocs/2601B-PULSE/92359.htm create mode 100644 WebHelpDocs/2601B-PULSE/92361.htm create mode 100644 WebHelpDocs/2601B-PULSE/92390.htm create mode 100644 WebHelpDocs/2601B-PULSE/92460.htm create mode 100644 WebHelpDocs/2601B-PULSE/92517.htm create mode 100644 WebHelpDocs/2601B-PULSE/92519.htm create mode 100644 WebHelpDocs/2601B-PULSE/92520.htm create mode 100644 WebHelpDocs/2601B-PULSE/92521.htm create mode 100644 WebHelpDocs/2601B-PULSE/92539.htm create mode 100644 WebHelpDocs/2601B-PULSE/92540.htm create mode 100644 WebHelpDocs/2601B-PULSE/92659.htm create mode 100644 WebHelpDocs/2601B-PULSE/92660.htm create mode 100644 WebHelpDocs/2601B-PULSE/92661.htm create mode 100644 WebHelpDocs/2601B-PULSE/92663.htm create mode 100644 WebHelpDocs/2601B-PULSE/92664.htm create mode 100644 WebHelpDocs/2601B-PULSE/92667.htm create mode 100644 WebHelpDocs/2601B-PULSE/92683.htm create mode 100644 WebHelpDocs/2601B-PULSE/92690.htm create mode 100644 WebHelpDocs/2601B-PULSE/92697.htm create mode 100644 WebHelpDocs/2601B-PULSE/92702.htm create mode 100644 WebHelpDocs/2601B-PULSE/92703.htm create mode 100644 WebHelpDocs/2601B-PULSE/92706.htm create mode 100644 WebHelpDocs/2601B-PULSE/92710.htm create mode 100644 WebHelpDocs/2601B-PULSE/92712.htm create mode 100644 WebHelpDocs/2601B-PULSE/92713.htm create mode 100644 WebHelpDocs/2601B-PULSE/92715.htm create mode 100644 WebHelpDocs/2601B-PULSE/92743.htm create mode 100644 WebHelpDocs/2601B-PULSE/92979.htm create mode 100644 WebHelpDocs/2601B-PULSE/92990.htm create mode 100644 WebHelpDocs/2601B-PULSE/92991.htm create mode 100644 WebHelpDocs/2601B-PULSE/92998.htm create mode 100644 WebHelpDocs/2601B-PULSE/92999.htm create mode 100644 WebHelpDocs/2601B-PULSE/93000.htm create mode 100644 WebHelpDocs/2601B-PULSE/93010.htm create mode 100644 WebHelpDocs/2601B-PULSE/93012.htm create mode 100644 WebHelpDocs/2601B-PULSE/93014.htm create mode 100644 WebHelpDocs/2601B-PULSE/93016.htm create mode 100644 WebHelpDocs/2601B-PULSE/93017.htm create mode 100644 WebHelpDocs/2601B-PULSE/93035.htm create mode 100644 WebHelpDocs/2601B-PULSE/93037.htm create mode 100644 WebHelpDocs/2601B-PULSE/93038.htm create mode 100644 WebHelpDocs/2601B-PULSE/93039.htm create mode 100644 WebHelpDocs/2601B-PULSE/93040.htm create mode 100644 WebHelpDocs/2601B-PULSE/93041.htm create mode 100644 WebHelpDocs/2601B-PULSE/93042.htm create mode 100644 WebHelpDocs/2601B-PULSE/93060.htm create mode 100644 WebHelpDocs/2601B-PULSE/93150.htm create mode 100644 WebHelpDocs/2601B-PULSE/93152.htm create mode 100644 WebHelpDocs/2601B-PULSE/93173.htm create mode 100644 WebHelpDocs/2601B-PULSE/93175.htm create mode 100644 WebHelpDocs/2601B-PULSE/93187.htm create mode 100644 WebHelpDocs/2601B-PULSE/93207.htm create mode 100644 WebHelpDocs/2601B-PULSE/93212.htm create mode 100644 WebHelpDocs/2601B-PULSE/93213.htm create mode 100644 WebHelpDocs/2601B-PULSE/93214.htm create mode 100644 WebHelpDocs/2601B-PULSE/93219.htm create mode 100644 WebHelpDocs/2601B-PULSE/AfterPublish.bat create mode 100644 WebHelpDocs/2601B-PULSE/EclipseHelpTemplate.html create mode 100644 WebHelpDocs/2601B-PULSE/Model 2601B-PULSE help files.hs create mode 100644 WebHelpDocs/2601B-PULSE/OracleToEclipse.exe create mode 100644 WebHelpDocs/2601B-PULSE/OracleToEclipse.xslt create mode 100644 WebHelpDocs/2601B-PULSE/caution_large_no_exclaim_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/contents1.gif create mode 100644 WebHelpDocs/2601B-PULSE/contents2.gif create mode 100644 WebHelpDocs/2601B-PULSE/contents3.gif create mode 100644 WebHelpDocs/2601B-PULSE/dhtml_search.htm create mode 100644 WebHelpDocs/2601B-PULSE/dhtml_search.js create mode 100644 WebHelpDocs/2601B-PULSE/exampleinstrumentcommanddescription.png create mode 100644 WebHelpDocs/2601B-PULSE/index1.gif create mode 100644 WebHelpDocs/2601B-PULSE/index2.gif create mode 100644 WebHelpDocs/2601B-PULSE/index3.gif create mode 100644 WebHelpDocs/2601B-PULSE/index_template.htm create mode 100644 WebHelpDocs/2601B-PULSE/jh_index.xml create mode 100644 WebHelpDocs/2601B-PULSE/jh_project.hs create mode 100644 WebHelpDocs/2601B-PULSE/jh_toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/map.jhm create mode 100644 WebHelpDocs/2601B-PULSE/notesmall_lr.png create mode 100644 WebHelpDocs/2601B-PULSE/nwvector.png create mode 100644 WebHelpDocs/2601B-PULSE/search.idx create mode 100644 WebHelpDocs/2601B-PULSE/search1.gif create mode 100644 WebHelpDocs/2601B-PULSE/search2.gif create mode 100644 WebHelpDocs/2601B-PULSE/search3.gif create mode 100644 WebHelpDocs/2601B-PULSE/stylesheet.css create mode 100644 WebHelpDocs/2601B-PULSE/tab_index.htm create mode 100644 WebHelpDocs/2601B-PULSE/tab_search.htm create mode 100644 WebHelpDocs/2601B-PULSE/tab_toc.htm create mode 100644 WebHelpDocs/2601B-PULSE/tail.gif create mode 100644 WebHelpDocs/2601B-PULSE/toc.hhc create mode 100644 WebHelpDocs/2601B-PULSE/toc.xml create mode 100644 WebHelpDocs/2601B-PULSE/toc_template.htm diff --git a/WebHelpDocs/2601B-PULSE/10835.htm b/WebHelpDocs/2601B-PULSE/10835.htm new file mode 100644 index 0000000..deccbc3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/10835.htm @@ -0,0 +1,44 @@ + + + + + Anonymous scripts + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Anonymous scripts

+

If a script is created with the loadscript or loadandrunscript command with no name defined, it is called the anonymous script. There can only be one anonymous script in the runtime environment. If another anonymous script is loaded into the runtime environment, it replaces the existing anonymous script.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/10905.htm b/WebHelpDocs/2601B-PULSE/10905.htm new file mode 100644 index 0000000..e264969 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/10905.htm @@ -0,0 +1,50 @@ + + + + + Event log + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Event log

+

You can use the event log to view specific details about LAN triggering events.

+

eventlog.all()

+

eventlog.clear()

+

eventlog.count

+

eventlog.enable

+

eventlog.next()

+

eventlog.overwritemethod

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11274.htm b/WebHelpDocs/2601B-PULSE/11274.htm new file mode 100644 index 0000000..cc43780 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11274.htm @@ -0,0 +1,44 @@ + + + + + Controlling digital I/O lines + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Controlling digital I/O lines

+

See the "Controlling digital I/O lines" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11382.htm b/WebHelpDocs/2601B-PULSE/11382.htm new file mode 100644 index 0000000..afbe6cf --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11382.htm @@ -0,0 +1,61 @@ + + + + + Bit manipulation and logic operations + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Bit manipulation and logic operations

+

The bit functions perform bitwise logic operations on two given numbers, and bit operations on one given number. Logic and bit operations truncate the fractional part of given numbers to make them integers.

+

Logic operations

+

The bit.bitand(), bit.bitor(), and bit.bitxor() functions in this group perform bitwise logic operations on two numbers. The Test Script Processor (TSP®) scripting engine performs the indicated logic operation on the binary equivalents of the two integers. This bitwise logic operation is performed on all corresponding bits of the two numbers. The result of a logic operation is returned as an integer.

+

Bit operations

+

The rest of the functions in this group are used for operations on the bits of a given number. These functions can be used to:

+
  • Clear a bit
  • Toggle a bit
  • Test a bit
  • Set a bit or bit field
  • Retrieve the weighted value of a bit or field value

All these functions use an index parameter to specify the bit position of the given number. The least significant bit of a given number has an index of 1, and the most significant bit has an index of 32.

+

VARIABLE - NOTE
The Test Script Processor (TSP) scripting engine stores all numbers internally as IEEE Std 754 double-precision floating-point values. The logical operations work on 32-bit integers. Any fractional bits are truncated. For numbers larger than 4294967295, only the lower 32 bits are used.

+

+

bit.bitand()

+

bit.bitor()

+

bit.bitxor()

+

bit.clear()

+

bit.get()

+

bit.getfield()

+

bit.set()

+

bit.setfield()

+

bit.test()

+

bit.toggle()

+ + + + +
+

See also

About TSP commands

Beeper control

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11440.htm b/WebHelpDocs/2601B-PULSE/11440.htm new file mode 100644 index 0000000..718ac58 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11440.htm @@ -0,0 +1,79 @@ + + + + + Autozero + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Autozero

+

The ADC of the 2601B-PULSE uses a ratiometric A/D conversion technique. To ensure reading accuracy, the instrument must periodically obtain fresh measurements of its internal ground and voltage reference. Separate reference and zero measurements are used for each aperture.

+

As summarized in the table below, there are different settings for autozero. By default, the instrument is set to AUTO, which automatically checks these reference measurements whenever a signal measurement is made. If the reference measurements are out of date when a signal measurement is made, the instrument automatically makes two more A/D conversions, one for the reference and one for the zero, before returning the result. Thus, occasionally, a measurement takes longer than normal.

+

This extra time can cause problems in sweeps and other test sequences in which measurement timing is critical. To avoid the extra time for the reference measurements in these situations, you can select OFF. This setting disables the automatic reference measurements. Note that with automatic reference measurements disabled, the instrument may gradually drift out of specification.

+

To minimize the drift, a reference and zero measurement should be made immediately before a critical test sequence. The ONCE setting can be used to force a refresh of the reference and zero measurements used for the current aperture setting.

+ + + + + + + + + + + + + + + + + + + + + +

Autozero settings

+

Autozero setting

+

Description

+

OFF

+

Turns automatic reference measurements off.

+

ONCE

+

After immediately making one reference and one zero measurement, turns automatic reference measurements off.

+

AUTO

+

Automatically takes new acquisitions when the 2601B-PULSE determines reference and zero values are out-of-date.

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11500.htm b/WebHelpDocs/2601B-PULSE/11500.htm new file mode 100644 index 0000000..f30c4c7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11500.htm @@ -0,0 +1,202 @@ + + + + + Digital I/O bit weighting + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Digital I/O bit weighting

+

Bit weighting for the digital I/O lines is shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Digital bit weight

+

Line #

+

Bit

+

Decimal weighting

+

Hexadecimal weighting

+

1

+

B1

+

1

+

0x0001

+

2

+

B2

+

2

+

0x0002

+

3

+

B3

+

4

+

0x0004

+

4

+

B4

+

8

+

0x0008

+

5

+

B5

+

16

+

0x0010

+

6

+

B6

+

32

+

0x0020

+

7

+

B7

+

64

+

0x0040

+

8

+

B8

+

128

+

0x0080

+

9

+

B9

+

256

+

0x0100

+

10

+

B10

+

512

+

0x0200

+

11

+

B11

+

1,024

+

0x0400

+

12

+

B12

+

2,048

+

0x0800

+

13

+

B13

+

4,096

+

0x1000

+

14

+

B14

+

8,192

+

0x2000

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11532.htm b/WebHelpDocs/2601B-PULSE/11532.htm new file mode 100644 index 0000000..c2fbdc8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11532.htm @@ -0,0 +1,44 @@ + + + + + Filters + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Filters

+

The filter feature lets you set the filter response to stabilize noisy measurements. The 2601B-PULSE uses a digital filter, which is based on reading conversions. The displayed, stored, or transmitted reading is calculated using one or more reading conversions (from 1 to 100).

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11584.htm b/WebHelpDocs/2601B-PULSE/11584.htm new file mode 100644 index 0000000..59d9b8d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11584.htm @@ -0,0 +1,46 @@ + + + + + Source or sink + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Source or sink

+

Depending on how it is programmed and what is connected to the output (load or source), the instrument can operate in any of the four quadrants. The four quadrants of operation are shown in the continuous operating boundaries figures. When operating in the first (I) or third (III) quadrant, the instrument is operating as a source (V and I have the same polarity). As a source, the instrument is delivering power to a load.

+

Four quadrants of operation

+

When operating in the second (II) or fourth (IV) quadrant, the instrument is operating as a sink (V and I have opposite polarity). As a sink, it is dissipating power rather than sourcing it. An external source or an energy storage device, such as a capacitor or battery, can force operation in the sink region.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11613.htm b/WebHelpDocs/2601B-PULSE/11613.htm new file mode 100644 index 0000000..273ba53 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11613.htm @@ -0,0 +1,46 @@ + + + + + Start-up (power-on) configuration + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Start-up (power-on) configuration

+

You can specify the 2601B-PULSE start-up (power-on) configuration. Use the setup.poweron attribute to select which setup to return to upon power-up. To set the setup.poweron configuration attribute:

+

setup.poweron = n -- Select power-on setup.

+

Where n is:

+
  • 0 (*RST or reset() factory defaults)
  • 1 to 5 (user setup 1 to 5)
+ + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11655.htm b/WebHelpDocs/2601B-PULSE/11655.htm new file mode 100644 index 0000000..c3e53db --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11655.htm @@ -0,0 +1,48 @@ + + + + + Remote reading buffer programming + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Remote reading buffer programming

+

You can get readings by making overlapped or sequential measurements. Overlapped commands do not finish executing before the next command starts. Sequential commands complete execution before the next command starts executing.

+

The measured value is not the only component of a reading. The measurement status (for example, “In Compliance” or “Overranged”) is also an element of data associated with a particular reading.

+

All routines that return measurements can store the measurements in the reading buffers. Overlapped measurements always return readings in a reading buffer. Non-overlapped measurement functions can return single-point measurement values or store multiple values in a reading buffer.

+

A reading buffer is based on a Lua table. The measurements are accessed by ordinary array accesses. If rb is a reading buffer, the first measurement is accessed as rb[1] and the ninth measurement as rb[9]. The additional information in the table is accessed as additional members of the table.

+

The load, save, and write operations for reading buffers function differently in the remote state. From a remote command interface, you can extract data from reading buffers as the instrument acquires the data.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11848.htm b/WebHelpDocs/2601B-PULSE/11848.htm new file mode 100644 index 0000000..c289496 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11848.htm @@ -0,0 +1,44 @@ + + + + + Sense mode selection + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Sense mode selection

+

The sense mode can be set to use 2-wire local sensing connections or 4-wire remote sensing connections. The default sense setting is 2-wire local.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11993.htm b/WebHelpDocs/2601B-PULSE/11993.htm new file mode 100644 index 0000000..69581d3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11993.htm @@ -0,0 +1,44 @@ + + + + + Range + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Range

+

The selected measurement range affects the accuracy of the measurements and the maximum signal that can be measured. If the range is changed, the front-panel display may contain dashes instead of a reading (for example, --.---- mA). This indicates that no measurement was made using the range that is presently selected. To update the displayed reading, trigger a measurement (if in local control, press the TRIG key).

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/11998.htm b/WebHelpDocs/2601B-PULSE/11998.htm new file mode 100644 index 0000000..4b25896 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/11998.htm @@ -0,0 +1,45 @@ + + + + + Speed + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Speed

+

The SPEED key can select and control the analog-to-digital converter (ADC) through setting the integration time, or measurement aperture (the period of time the input signal is measured). The integration time affects the usable digits, the amount of reading noise, and the reading rate of the instrument. The integration time is specified in parameters based on the number of power line cycles (NPLC), where 1 PLC for 60 Hz is 16.67 ms (1/60) and 1 PLC for 50 Hz is 20 ms (1/50).

+

In general, the fastest integration time (0.001 PLC) results in the fastest reading rate, but also causes increased reading noise and fewer usable digits. The slowest integration time (25 PLC) provides the best common-mode and normal-mode noise rejection, but has the slowest reading rate. Settings between the fastest and slowest integration times are a compromise between speed and noise. The default power-on speed setting is NORMAL (1 PLC).

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12001.htm b/WebHelpDocs/2601B-PULSE/12001.htm new file mode 100644 index 0000000..f388f21 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12001.htm @@ -0,0 +1,48 @@ + + + + + Relative offset + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Relative offset

+

When making measurements, you may want to subtract an offset value from a measurement.

+

The relative offset feature subtracts a set value or a baseline reading from measurement readings. When you enable relative offset, all measurements are recorded as the difference between the actual measured value and the relative offset value. The formula to calculate the offset value is:

+

Displayed value = Actual measured value - Relative offset value

+

When a relative offset value is established for a measure function, the value is the same for all ranges for that measure function. For example, if 0.5 A is set as a relative offset value on the 1 A range, the relative offset value is also 0.5 A on the lower current ranges. Also, on the 1 A range, the 2601B-PULSE still overflows for a more than 1.02 A input.

+

When relative offset is enabled, the REL indicator turns on. Changing measurement functions changes the relative offset value to the established relative offset value and state for that measurement function.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12044.htm b/WebHelpDocs/2601B-PULSE/12044.htm new file mode 100644 index 0000000..126f988 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12044.htm @@ -0,0 +1,43 @@ + + + + + Time and date values + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Time and date values

+

Time and date values are represented as the number of seconds since some base. Representing time as a number of seconds is referred to as “standard time format.” There are three time bases:

+
  • UTC 12:00 am Jan 1, 1970. Some examples of UTC time are reading buffer base timestamps, adjustment dates, and the value returned by os.time().
  • Instrument on. References time to when the instrument was turned on. The value returned by os.clock() is referenced to the turn-on time.
  • Event. Time referenced to an event, such as the first reading stored in a reading buffer.
+ + + +
+

See also

TSP command programming notes

Placeholder text

Syntax rules

Settings ignored when the pulser is enabled

Settings ignored when the pulser is disabled

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12125.htm b/WebHelpDocs/2601B-PULSE/12125.htm new file mode 100644 index 0000000..51bb972 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12125.htm @@ -0,0 +1,45 @@ + + + + + Capturing key-press codes + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Capturing key-press codes

+

A history of the key code for the last pressed front-panel key is maintained by the 2601B-PULSE. When the instrument is turned on (or when transitioning from local to remote operation), the key code is set to 0 (display.KEY_NONE).

+

When a front-panel key is pressed, the key code value for that key can be captured and returned. There are two functions associated with the capture of key-press codes: display.getlastkey() and display.waitkey().

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12137.htm b/WebHelpDocs/2601B-PULSE/12137.htm new file mode 100644 index 0000000..fe1f4b1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12137.htm @@ -0,0 +1,45 @@ + + + + + Display resolution + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Display resolution

+

Display resolution for measured readings can be set to 4-1/2, 5-1/2 or 6-1/2. Configure the type of resolution displayed by setting the display.smua.digits attribute. The following programming example illustrates how to set 5-1/2 digit resolution for measured readings:

+

display.smua.digits = display.DIGITS_5_5

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12175.htm b/WebHelpDocs/2601B-PULSE/12175.htm new file mode 100644 index 0000000..e989a8c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12175.htm @@ -0,0 +1,50 @@ + + + + + KISweep factory script + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

KISweep factory script

+

The KISweep factory script provides simple sweep test programming and shows how to use the sweeping function.

+

This script is made up of the following functions. Access these functions from the front panel or the remote interfaces. The following functions make up the KISweep factory script:

+

SweepILinMeasureV()

+

SweepIListMeasureV()

+

SweepILogMeasureV()

+

SweepVLinMeasureI()

+

SweepVListMeasureI()

+

SweepVLogMeasureI()

+ + + + +
+

See also

Factory scripts

Running a factory script

Retrieving and modifying a factory script listing

KIHighC factory script

KIParlib factory script

KISavebuffer factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12177.htm b/WebHelpDocs/2601B-PULSE/12177.htm new file mode 100644 index 0000000..f10a91b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12177.htm @@ -0,0 +1,116 @@ + + + + + SweepILinMeasureV() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

SweepILinMeasureV()

+

This KISweep factory script function performs a linear current sweep with voltage measured at every step (point).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

SweepILinMeasureV(smua, starti, stopi, stime, points)

+

+ + + + + + + + + + + + + + + + + + +

starti

+

Sweep start current in amperes

+

stopi

+

Sweep stop current in amperes

+

stime

+

Settling time in seconds; occurs after stepping the source and before making a measurement

+

points

+

Number of sweep points (must be >= 2)

+
+

Details

+

Data for voltage measurements, current source values, and timestamps are stored in smua.nvbuffer1.

+

If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.

+

Performs a linear current sweep with voltage measured at every step (point):

+
  1. Sets the SMU to output starti amperes, allows the source to settle for stime seconds, and then makes a voltage measurement.
  2. Sets the SMU to output the next amperes step, allows the source to settle for stime seconds, and then makes a voltage measurement.
  3. Repeats the above sequence until the voltage is measured on the stopi amperes step.

The linear step size is automatically calculated as follows:

+

step = (stopi – starti) / (points – 1)

+

SweepILinMeasureV()

+

Example

+

+ + + + + + + + +

SweepILinMeasureV(smua, -1e-3, 1e-3, 0, 100)

+

This function performs a 100-point linear current sweep starting at -1 mA and stopping at +1 mA. Voltage is measured at every step (point) in the sweep. Because stime is set for 0 s, voltage is measured as quickly as possible after each current step.

+
+

Also see

+

KISweep factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12181.htm b/WebHelpDocs/2601B-PULSE/12181.htm new file mode 100644 index 0000000..a7d010e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12181.htm @@ -0,0 +1,116 @@ + + + + + SweepVLinMeasureI() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

SweepVLinMeasureI()

+

This KISweep factory script function performs a linear voltage sweep with current measured at every step (point).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

SweepVLinMeasureI(smua, startv, stopv, stime, points)

+

+ + + + + + + + + + + + + + + + + + +

startv

+

Sweep start voltage in volts

+

stopv

+

Sweep stop voltage in volts

+

stime

+

Settling time in seconds; occurs after stepping the source and before making a measurement

+

points

+

Number of sweep points (must be >= 2)

+
+

Details

+

Data for current measurements, voltage source values, and timestamps are stored in smua.nvbuffer1.

+

If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.

+

Performs a linear voltage sweep with current measured at every step (point):

+
  1. Sets the SMU to output startv amperes, allows the source to settle for stime seconds, and then makes a current measurement.
  2. Sets the SMU to output the next amperes step, allows the source to settle for stime seconds, and then makes a voltage measurement.
  3. Repeats the above sequence until the voltage is measured on the stopv amperes step.

The linear step size is automatically calculated as follows:

+

step = (stopv – startv) / (points – 1)

+

SweepVLinMeasureI()

+

Example

+

+ + + + + + + + +

SweepVLinMeasureI(smua, -1, 1, 1e-3, 1000)

+

This function performs a 1000-point linear voltage sweep starting at -1 V and stopping at +1 V. Current is measured at every step (point) in the sweep after a 1 ms source settling period.

+
+

Also see

+

KISweep factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12184.htm b/WebHelpDocs/2601B-PULSE/12184.htm new file mode 100644 index 0000000..1465ca8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12184.htm @@ -0,0 +1,186 @@ + + + + + SweepILogMeasureV() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

SweepILogMeasureV()

+

This KISweep factory script function performs a logarithmic current sweep with voltage measured at every step (point).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

SweepILogMeasureV(smua, starti, stopi, stime, points)

+

+ + + + + + + + + + + + + + + + + + +

starti

+

Sweep start current in amperes

+

stopi

+

Sweep stop current in amperes

+

stime

+

Settling time in seconds; occurs after stepping the source and before making a measurement

+

points

+

Number of sweep points (must be >= 2)

+
+

Details

+

Data for voltage measurements, current source values, and timestamps are stored in smua.nvbuffer1.

+

If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.

+

Performs a logarithmic current sweep with voltage measured at every step (point):

+
  1. Sets the SMU to output starti amperes value, allows the source to settle for stime seconds, and then performs a voltage measurement.
  2. Sets the SMU to output the next amperes step, allows the source to settle for stime seconds, and then performs a voltage measurement.
  3. Repeats the above sequence until the voltage is measured on the stopi amperes step.

The source level at each step (SourceStepLevel) is automatically calculated as follows:

+

MeasurePoint = The step point number for a measurement

+

For example, for a five-point sweep (points = 5), a measurement is performed at MeasurePoint 1, 2, 3, 4, and 5.

+

LogStepSize = (log10(stopi) – log10(starti)) / (points – 1)

+

LogStep = (MeasurePoint – 1) * (LogStepSize)

+

SourceStepLevel = antilog(LogStep) * starti

+

SweepILogMeasureV()

+

Example

+

+ + + + + + + + +

SweepILogMeasureV(smua, 0.01, 0.1, 0.001, 5)

+

This function performs a five-point linear current sweep starting at 10 mA and stopping at 100 mA. Voltage is measured at every step (point) in the sweep. The source is allowed to settle on each step for 1 ms before a measurement is made.

+

 

+

The following table contains log values and corresponding source levels for the five-point logarithmic sweep:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

MeasurePoint

+

LogStepSize

+

LogStep

+

SourceStepLevel

+

1

+

0.25

+

0.0

+

0.01 A

+

2

+

0.25

+

0.25

+

0.017783 A

+

3

+

0.25

+

0.5

+

0.031623 A

+

4

+

0.25

+

0.75

+

0.056234 A

+

5

+

0.25

+

1.0

+

0.1 A

+
+

 

+
+

Also see

+

KISweep factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12190.htm b/WebHelpDocs/2601B-PULSE/12190.htm new file mode 100644 index 0000000..03a57c4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12190.htm @@ -0,0 +1,109 @@ + + + + + SweepIListMeasureV() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

SweepIListMeasureV()

+

This KISweep factory script function performs a current list sweep with voltage measured at every step (point).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

SweepIListMeasureV(smua, ilist, stime, points)

+

+ + + + + + + + + + + + + + +

ilist

+

Arbitrary list of current source values; ilist = {value1, value2, ...valueN}

+

stime

+

Settling time in seconds; occurs after stepping the source and before making a measurement

+

points

+

Number of sweep points (must be >= 2)

+
+

Details

+

Data for voltage measurements, current source values, and timestamps are stored in smua.nvbuffer1.

+

If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.

+

Performs a current list sweep with voltage measured at every step (point):

+
  1. Sets the SMU to output ilist amperes value, allows the source to settle for stime seconds, and then performs a voltage measurement.
  2. Sets the SMU to output the next ilist step, allows the source to settle for stime seconds, and then performs a voltage measurement.
  3. Repeats the above sequence until the voltage is measured for the last amperes value. The last point in the list to be measured is points.

Example

+

+ + + + + + + + +

testilist = {-100e-9, 100e-9, -1e-6, 1e-6, -1e-3, 1e-3}

+

 

+

SweepIListMeasureV(smua, testilist, 500e-3, 6)

+

This function performs a six-point current list sweep starting at the first point in testilist. Voltage is measured at every step (point) in the sweep. The source is allowed to settle on each step for 500 ms before a measurement is performed.

+
+

Also see

+

KISweep factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12192.htm b/WebHelpDocs/2601B-PULSE/12192.htm new file mode 100644 index 0000000..38c1f5d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12192.htm @@ -0,0 +1,187 @@ + + + + + SweepVLogMeasureI() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

SweepVLogMeasureI()

+

This KISweep factory script function performs a logarithmic voltage sweep with current measured at every step (point).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

SweepVLogMeasureI(smua, startv, stopv, stime, points)

+

+ + + + + + + + + + + + + + + + + + +

startv

+

Sweep start voltage in volts

+

stopv

+

Sweep stop voltage in volts

+

stime

+

Settling time in seconds; occurs after stepping the source and before making a measurement

+

points

+

Number of sweep points (must be >= 2)

+
+

Details

+

Data for current measurements, voltage source values, and timestamps are stored in smua.nvbuffer1.

+

If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.

+

Performs a logarithmic voltage sweep with current measured at every step (point):

+
  1. Sets the SMU to output startv amperes, allows the source to settle for stime seconds, and then makes a current measurement.
  2. Sets the SMU to output the next volts step, allows the source to settle for stime seconds, and then makes a current measurement.
  3. Repeats the above sequence until the voltage is measured on the stopv volts step.

The source level at each step (SourceStepLevel) is automatically calculated as follows:

+

MeasurePoint = The step point number for a measurement

+

For example, for a five-point sweep (points = 5), a measurement is made at MeasurePoint 1, 2, 3, 4, and 5.

+

LogStepSize = (log10(stopi) – log10(starti)) / (points – 1)

+

LogStep = (MeasurePoint – 1) * (LogStepSize)

+

SourceStepLevel = antilog(LogStep) * startv

+

SweepVLogMeasureI()

+

Example

+

+ + + + + + + + +

SweepVLogMeasureI(smua, 1, 10, 0.001, 5)

+

This function performs a five-point logarithmic voltage sweep starting at 1 V and stopping at 10 V. Current is measured at every step (point) in the sweep after a 1 ms source settling period.

+

 

+

The following table contains log values and corresponding source levels for the five-point logarithmic sweep:

+

 

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

MeasurePoint

+

LogStepSize

+

LogStep

+

SourceStepLevel

+

1

+

0.25

+

0.0

+

1.0000 V

+

2

+

0.25

+

0.25

+

1.7783 V

+

3

+

0.25

+

0.5

+

3.1623 V

+

4

+

0.25

+

0.75

+

5.6234 V

+

5

+

0.25

+

1.0

+

10.000 V

+
+

 

+
+

Also see

+

KISweep factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12194.htm b/WebHelpDocs/2601B-PULSE/12194.htm new file mode 100644 index 0000000..03b6d5b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12194.htm @@ -0,0 +1,49 @@ + + + + + Retrieving and modifying a factory script listing + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Retrieving and modifying a factory script listing

+

The script listing for a factory script can be retrieved and modified. However, it cannot be saved as a factory script. The modified script can be saved as a user script using the same name or a new name.

+

An imported factory script can only be loaded back into the 2601B-PULSE as a user script.

+

The following function retrieves a script listing. The script code is output with the shell keywords (loadscript or loadandrunscript and endscript):

+

script.factory.scripts.name.list()

+

Where: name is the name of the factory script.

+

An example that retrieves the script listing for a factory script named KISweep:

+

script.factory.scripts.KISweep.list()

+ + + + +
+

See also

Factory scripts

Running a factory script

KISweep factory script

KIHighC factory script

KIParlib factory script

KISavebuffer factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12259.htm b/WebHelpDocs/2601B-PULSE/12259.htm new file mode 100644 index 0000000..3cb478a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12259.htm @@ -0,0 +1,82 @@ + + + + + Error queue + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Error queue

+

The error queue holds error and status messages. As programming errors and status messages occur, a message that defines the error or status is placed in the error queue.

+

An error or status message is cleared from the error queue when it is read. You can also clear the error queue by sending the command errorqueue.clear(). An empty error queue clears the error available (EAV) bit in the Status Byte Register.

+

Messages in the error queue include a code number, message text, severity, and TSP-Link® node number. See Error summary list for a list of the messages.

+

When you read a single message from the error queue, the oldest message is read. If you attempt to read the error queue when it is empty, the error number 0 and “No Error” is returned.

+

The commands that can be used to control the error queue are listed below.

+ + + + + + + + + + + + + + + + + + + + + +

Error queue commands

+

Error queue command

+

Description

+

errorqueue.clear()

+

Clear error queue of all errors.

+

errorqueue.count

+

Number of messages in the error/event queue.

+

errorCode, message,

+

severity, errorNode =

+

errorqueue.next()

+

Request error code, text message, severity, and TSP-Link node number.

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12451.htm b/WebHelpDocs/2601B-PULSE/12451.htm new file mode 100644 index 0000000..be96113 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12451.htm @@ -0,0 +1,44 @@ + + + + + Digital I/O port + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Digital I/O port

+

The Keithley Instruments 2601B-PULSE System SourceMeter® instrument has a digital input/output port that can be used to control external digital circuitry. For example, a handler that is used to perform binning operations can be used with a digital I/O port.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12571.htm b/WebHelpDocs/2601B-PULSE/12571.htm new file mode 100644 index 0000000..9e65a9a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12571.htm @@ -0,0 +1,230 @@ + + + + + Understanding hardware value and pseudo line state + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Understanding hardware value and pseudo line state

+

LAN triggering is similar to hardware synchronization except that LXI trigger packets are used instead of hardware signals. A bit in the LXI trigger packet called the hardware value simulates the state of a hardware trigger line. The 2601B-PULSE stores the hardware value of the last LXI trigger packet that was sent or received as the pseudo line state.

+

The stateless event flag is a bit in the LXI trigger packet that indicates if the hardware value should be ignored. If it is set, the 2601B-PULSE ignores the hardware value of the packet and generates a trigger event. The 2601B-PULSE always sets the stateless flag for outgoing LXI trigger packets. If the stateless event flag is not set, the hardware value indicates the state of the signal.

+

Changes in the hardware value of consecutive LXI trigger packets are interpreted as edge transitions. Edge transitions generate trigger events. If the hardware value does not change between successive LXI trigger packets, the 2601B-PULSE assumes an edge transition was missed and generates a trigger event. The following table illustrates edge detection in LAN triggering.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

 

+

LXI trigger edge detection

+

Stateless event flag

+

Hardware value

+

Pseudo line state

+

Falling edge

+

Rising edge

+

0

+

0

+

0

+

Detected

+

Detected

+

0

+

1

+

0

+

-

+

Detected

+

0

+

0

+

1

+

Detected

+

-

+

0

+

1

+

1

+

Detected

+

Detected

+

1

+

-

+

-

+

Detected

+

Detected

+
+

+

Set the LAN trigger mode to configure the edge detection method in incoming LXI trigger packets. The mode that is selected also determines the hardware value in outgoing LXI trigger packets. The following table lists the LAN trigger modes.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

 

+

LAN trigger modes

+

Trigger mode

+

Input detected

+

Output generated

+

Notes

+

Either edge

+

Either

+

Negative

+

 

+

Falling edge

+

Falling

+

Negative

+

 

+

Rising edge

+

Rising

+

Positive

+

 

+

RisingA

+

Rising

+

Positive

+

Same as Rising

+

RisingM

+

Rising

+

Positive

+

Same as Rising

+

Synchronous

+

Falling

+

Positive

+

Same as SynchronousA

+

SynchronousA

+

Falling

+

Positive

+

 

+

SynchronousM

+

Rising

+

Negative

+

 

+
+

+

The programming example below illustrates how to configure the LAN trigger mode.

+

-- Set LAN trigger 2 to have falling-edge mode.

+

lan.trigger[2].mode = lan.TRIG_FALLING

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12893.htm b/WebHelpDocs/2601B-PULSE/12893.htm new file mode 100644 index 0000000..c8891b0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12893.htm @@ -0,0 +1,71 @@ + + + + + Logical operators + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Logical operators

+

The logical operators in Lua are and, or, and not. All logical operators consider both false and nil as false and anything else as true.

+

The operator not always returns false or true.

+

The conjunction operator and returns its first argument if the first argument is false or nil; otherwise, and returns its second argument. The disjunction operator or returns its first argument if this value is different from nil and false; otherwise, or returns its second argument. Both and and or use shortcut evaluation, that is, the second operand is evaluated only if necessary.

+

VARIABLE - NOTE
The example output you get may vary depending on the data format settings of the instrument.

+

Example

+

+ + + + + + +

print(10 or errorqueue.next())

+

print(nil or "a")

+

print(nil and 10)

+

print(false and errorqueue.next())

+

print(false and nil)

+

print(false or nil)

+

print(10 and 20)

+

1.00000e+01

+

a

+

nil

+

false

+

false

+

nil

+

2.00000e+01

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12911.htm b/WebHelpDocs/2601B-PULSE/12911.htm new file mode 100644 index 0000000..a150221 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12911.htm @@ -0,0 +1,51 @@ + + + + + Factory scripts + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Factory scripts

+

The Keithley Instruments 2601B-PULSE System SourceMeter® instrument is shipped with one or more factory scripts saved in its flash firmware memory. A factory script is made up of a number of functions. Some of them can be called from the front-panel LOAD TEST menu. All of them can be called using remote programming.

+

As Keithley Instruments develops additional factory scripts, they will be made available on tek.com/keithley as a flash firmware upgrade for the 2601B-PULSE. See Upgrading the firmware for instructions on upgrading the flash firmware of your 2601B-PULSE instrument.

+

A factory script is similar to a user script, except a factory script is created by Keithley Instruments at the factory and is permanently stored in nonvolatile memory. The differences between a user script and a factory script include the following:

+
  • A factory script cannot be deleted from nonvolatile memory.
  • The script listing for a factory script can be retrieved and modified, but it is then treated as a user script. A user script cannot be saved as a factory script.
  • Factory scripts are not stored in global variables. The only references to factory scripts are in the script.factory.scripts attribute.
  • The script.factory.catalog() function returns an iterator that can be used in a for loop to iterate over all the factory scripts.

Example

+

To retrieve the catalog listing for factory scripts, send:

+

for name in script.factory.catalog() do print(name) end

+ + + + + +
+

In this section

Running a factory script

Retrieving and modifying a factory script listing

KISweep factory script

KIHighC factory script

KIParlib factory script

KISavebuffer factory script

+

See also

Remote commands

Introduction to TSP operation

About TSP commands

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12913.htm b/WebHelpDocs/2601B-PULSE/12913.htm new file mode 100644 index 0000000..787b512 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12913.htm @@ -0,0 +1,50 @@ + + + + + Running a factory script + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Running a factory script

+

Use either of the following commands to run a factory script:

+

script.factory.scripts.name()
script.factory.scripts.name.run()

+

Where: name is the name of the factory script.

+

Example:

+

Run the factory script named KISweep.

+

script.factory.scripts.KISweep()

+ + + + + +
+

In this section

Running a factory script function from the front-panel controls

+

See also

Factory scripts

Retrieving and modifying a factory script listing

KISweep factory script

KIHighC factory script

KIParlib factory script

KISavebuffer factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12914.htm b/WebHelpDocs/2601B-PULSE/12914.htm new file mode 100644 index 0000000..f5aadb4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12914.htm @@ -0,0 +1,42 @@ + + + + + Running a factory script function from the front-panel controls + + + + + + + + + +
+

Previous Icon

+

Next Icon

+
Running a factory script function from the front-panel controls
+
  1. Press the LOAD key.
  2. Select FACTORY.
  3. Select the function to run and press the ENTER key or navigation wheel navigation wheel.
  4. Press the RUN key.
  5. Follow the prompts on the front panel to run the script.
+ + + +
+

See also

Running a factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12950.htm b/WebHelpDocs/2601B-PULSE/12950.htm new file mode 100644 index 0000000..bc289c8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12950.htm @@ -0,0 +1,45 @@ + + + + + KIHighC factory script + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

KIHighC factory script

+

The KIHighC factory script is made up of two functions: i_leakage_measure() and i_leakage_threshold(). These functions are intended to be used when high capacitance mode is active. Output is generally at a non-zero voltage before calling these functions. These functions can also be used to step the voltage to zero volts in order to measure the leakage current.

+

i_leakage_measure()

+

i_leakage_threshold()

+ + + + +
+

See also

Factory scripts

Running a factory script

Retrieving and modifying a factory script listing

KISweep factory script

KIParlib factory script

KISavebuffer factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12951.htm b/WebHelpDocs/2601B-PULSE/12951.htm new file mode 100644 index 0000000..3c38e21 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12951.htm @@ -0,0 +1,139 @@ + + + + + i_leakage_measure() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

i_leakage_measure()

+

This KIHighC factory script function performs a current leakage measurement after stepping the output voltage.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

imeas = i_leakage_measure(smua, levelv, limiti, sourcedelay, measurei, measuredelay)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

imeas

+

The measured current

+

levelv

+

Voltage level to step to when this function is called

+

limiti

+

Current limit setting for the voltage step

+

sourcedelay

+

Delay to wait before lowering the current limit for measurement

+

measurei

+

Current limit (and measure range); note the current limit is lower at this level and because high-capacitance mode is active, the measure range will follow

+

measuredelay

+

Delay to wait after lowering the current limit before taking the measurement

+
+

Details

+

This function causes the SMU to:

+
  • Change its current limit to limiti with a voltage output of levelv for sourcedelay time, and then change its current limit to measurei (that also changes the measurement range to measurei) for measuredelay time
  • When measuredelay time expires, a measurement is made and returned as imeas

When measuring leakage current:

+
  • Charge the capacitor before calling this function (the output of the instrument is usually at a nonzero voltage before calling this function; when measuring leakage, this function does not charge the capacitor)
  • Set levelv = 0

Example

+

+ + + + + + + + +

smua.source.highc = smua.ENABLE

+

smua.source.levelv = 5

+

smua.source.output = smua.OUTPUT_ON

+

delay(1)

+

imeas = i_leakage_measure(smua, 0, 1, 300e-3, 10e-6, 0.1)

+

Enable high-capacitance mode. Charge the capacitor at 5 V for 1 second set
by delay(1).

+

 

+

The parameters passed on to the i_leakage_measure() function in this example are:

+

smu = smua

+

levelv = 0 V

+

limiti = 1 A

+

sourcedelay = 300 ms

+

measurei = 10 µA range

+

measuredelay = 100 ms

+

The levels and delays depend on the value and type of capacitor used.

+
+

Also see

+

i_leakage_threshold()

+

High-capacitance mode

+

KIHighC factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12953.htm b/WebHelpDocs/2601B-PULSE/12953.htm new file mode 100644 index 0000000..9c3e604 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12953.htm @@ -0,0 +1,156 @@ + + + + + i_leakage_threshold() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

i_leakage_threshold()

+

This KIHighC factory script function measures the current and compares it to a threshold. This continues until either the measured current drops below the threshold or the timeout expires.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

f = i_leakage_threshold(smua, levelv, limiti, sourcedelay, measurei, measuredelay, threshold, timeout)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

f

+

A Boolean flag; this flag is true when the current is below the threshold, false if threshold is not reached before timeout expires

+

levelv

+

Voltage level to step to when this function is called

+

limiti

+

Current limit setting for the voltage step

+

sourcedelay

+

Delay to wait before lowering the current limit for measurement

+

measurei

+

Current limit (and measure range); note the current limit is lower at this level and because high-capacitance mode is active, the measure range will follow

+

measuredelay

+

Delay before the first measurement after measure range is changed

+

threshold

+

The specified current that establishes the test limit

+

timeout

+

Amount of time (in seconds) to wait for the current to drop to threshold after all the delays have occurred

+
+

Details

+

This function causes the SMU to:

+
  • Change its current limit to limiti with a voltage output of levelv for sourcedelay time, and then changes its current limit to measurei (that also changes the measurement range to measurei) for measuredelay time.
  • When measuredelay time expires, measurements are taken at a rate determined by the smua.measure.nplc setting.

When testing the leakage current threshold:

+
  • Charge the capacitor before calling this function. The output of the instrument is usually at a non-zero voltage before calling this function; when measuring leakage, this function does not charge the capacitor.
  • If testing the leakage current threshold of the device, set levelv = 0.

Example

+

+ + + + + + + + +

smua.source.highc = smua.ENABLE

+

smua.source.levelv = 5

+

smua.source.output = smua.OUTPUT_ON

+

delay(1)

+

pass = i_leakage_threshold(smua, 0, 1, 300e-3, 10e-6, 100e-3, 1e-6, 1)

+

Enable high-capacitance mode.

+

Charge the capacitor.

+

 

+

The parameters passed on to the i_threshold_measure() function in this example are:

+

smu = smua

+

levelv = 0 V

+

limiti = 1 A

+

sourcedelay = 300 ms

+

measurei = 10 µA range

+

measuredelay = 100 ms

+

threshold = 1 µA

+

timeout = 1 s

+

The levels and delays depend on the value and type of capacitor used.

+

Sets pass = true if the current is measured below 1 µA in less than 1 second.

+
+

Also see

+

High-capacitance mode

+

i_leakage_measure()

+

High-capacitance mode

+

KIHighC factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12954.htm b/WebHelpDocs/2601B-PULSE/12954.htm new file mode 100644 index 0000000..7106999 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12954.htm @@ -0,0 +1,45 @@ + + + + + KIParlib factory script + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

KIParlib factory script

+

The KIParlib factory script is made up of two functions: gm_vsweep() and gm_isweep().

+

gm_vsweep()

+

gm_isweep()

+ + + + +
+

See also

Factory scripts

Running a factory script

Retrieving and modifying a factory script listing

KISweep factory script

KIHighC factory script

KISavebuffer factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12955.htm b/WebHelpDocs/2601B-PULSE/12955.htm new file mode 100644 index 0000000..4959ea1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12955.htm @@ -0,0 +1,138 @@ + + + + + gm_vsweep() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

gm_vsweep()

+

This KIParlib factory script function performs a linear voltage sweep and calculates the transconductance (Gm) at each point.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

gm_array, ibuf, vbuf = gm_vsweep(smu, start_v, stop_v, points)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

gm_array

+

A Lua table containing the calculated Gm values at each point

+

ibuf

+

A reading buffer containing the measured current at each point

+

vbuf

+

A reading buffer containing the measured voltage at each point

+

smu

+

Instrument channel (for example, smua refers to SMU channel A)

+

start_v

+

Starting voltage level of the sweep

+

stop_v

+

Ending voltage level of the sweep

+

points

+

Number of measurements between start_v and stop_v (must be >= 2)

+
+

Details

+

Output data includes transconductance values, reading buffer with measured currents, reading buffer with measured currents and voltages.

+

The gm_vsweep() function performs a linear voltage sweep, measuring voltage and current, and then calculating the transconductance (Gm) at each point using the central difference method. It can return an array of Gm values, a reading buffer with the measured currents, and a reading buffer with the measured voltages.

+

Example

+

+ + + + + + +

gm_array = gm_vsweep(smua, 0, 5, 20)

+

 

+

gm_array, ibuf = gm_vsweep(smua, 0, 5, 20)

+

 

+

 

+

gm_array, ibuf, vbuf = gm_vsweep(smua, 0, 5, 20)

+

SMU A returns Gm values only.

+

 

+

SMU A returns Gm and reading buffer with measured currents.

+

 

+

SMU A returns Gm and reading buffers with measured currents and voltages.

+
+

Also see

+

gm_isweep()

+

KIParlib factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12957.htm b/WebHelpDocs/2601B-PULSE/12957.htm new file mode 100644 index 0000000..97af403 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12957.htm @@ -0,0 +1,141 @@ + + + + + gm_isweep() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

gm_isweep()

+

This KIParlib factory script function performs a linear current sweep and calculates the transconductance (Gm) at each point.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

gm_array, vbuf, ibuf = gm_isweep(smu, start_i, stop_i, points)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

gm_array

+

A Lua table containing the calculated Gm values at each point

+

vbuf

+

A reading buffer containing the measured voltage at each point

+

ibuf

+

A reading buffer containing the measured current at each point

+

smu

+

Instrument channel (for example, smua refers to SMU channel A)

+

start_i

+

Starting current level of the sweep

+

stop_i

+

Ending current level of the sweep

+

points

+

Number of measurements between start_i and stop_i (must be >= 2)

+
+

Details

+

Output data includes transconductance values, reading buffer with measured voltages, reading buffer with measured voltages and currents.

+

If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.

+

The gm_isweep() function performs a linear current sweep, measuring voltage and current, and then calculating the transconductance (Gm) at each point using the central difference method. It can return an array of Gm values, a reading buffer with the measured voltages, and a reading buffer with the measured currents.

+

Example

+

+ + + + + + +

gm_array = gm_isweep(smua, 0, 0.01, 20)

+

 

+

 

+

gm_array, vbuf = gm_isweep(smua, 0, 0.01, 20)

+

 

+

 

+

gm_array, vbuf, ibuf = gm_isweep(smua, 0,

+

0.01, 20)

+

Source-measure unit (SMU) A returns Gm values only.

+

 

+

SMU A returns Gm and reading buffer with measured voltages.

+

 

+

SMU A returns Gm and reading buffers with measured voltages and currents.

+
+

Also see

+

gm_vsweep()

+

KIParlib factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12958.htm b/WebHelpDocs/2601B-PULSE/12958.htm new file mode 100644 index 0000000..40782ff --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12958.htm @@ -0,0 +1,44 @@ + + + + + KISavebuffer factory script + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

KISavebuffer factory script

+

The KISavebuffer script has one function: savebuffer().

+

savebuffer()

+ + + + +
+

See also

Factory scripts

Running a factory script

Retrieving and modifying a factory script listing

KISweep factory script

KIHighC factory script

KIParlib factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/12959.htm b/WebHelpDocs/2601B-PULSE/12959.htm new file mode 100644 index 0000000..bd43bf9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/12959.htm @@ -0,0 +1,121 @@ + + + + + savebuffer() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

savebuffer()

+

This KISavebuffer factory script function saves a specified reading buffer as either a CSV file or an XML file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

savebuffer(buffer, "formatType", "fileName")

+

+ + + + + + + + + + + + + + +

buffer

+

The reading buffer to save

+

formatType

+

A string indicating which file type to use: csv or xml

+

fileName

+

The file name of the saved buffer

+
+

Details

+

Use this function to save the specified buffer to a USB flash drive.

+

This function will only save to a USB flash drive.

+

You are not required to qualify the path to the USB flash drive, but you can add /usb1/ before the fileName (see Example 2).

+

Example 1

+

+ + + + + + + + +

savebuffer(smua.nvbuffer1, "csv", "mybuffer.csv")

+

Save smua dedicated reading buffer 1 as a CSV file named mybuffer.csv.

+
+

Example 2

+

+ + + + + + + + +

savebuffer(smua.nvbuffer1, "csv", "/usb1/mybuffer.csv")

+

Save smua dedicated reading buffer 1 to an installed USB flash drive as a CSV file named mybuffer.csv.

+
+

Also see

+

KISavebuffer factory script

+

smua.savebuffer()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13401.htm b/WebHelpDocs/2601B-PULSE/13401.htm new file mode 100644 index 0000000..6bdd519 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13401.htm @@ -0,0 +1,46 @@ + + + + + About TSP commands + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

About TSP commands

+

This section contains an overview of the TSP commands for the instrument. The commands are organized into groups, with a brief description of each group. Each section contains links to the detailed descriptions for each command in the TSP command reference section of this documentation (see TSP commands).

+ + + + + +
+

In this section

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+

See also

Remote commands

Introduction to TSP operation

Factory scripts

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13605.htm b/WebHelpDocs/2601B-PULSE/13605.htm new file mode 100644 index 0000000..9e52da6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13605.htm @@ -0,0 +1,47 @@ + + + + + Autoranging + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Autoranging

+

To use automatic source ranging, press SRC then the AUTO range key.

+

To use automatic measure ranging, press the MEAS key followed by the AUTO range key. The AUTO indicator turns on when source or measure autoranging is selected.

+

When autorange is selected, the instrument automatically sets the best range to source or measure the applied signal. The instrument will uprange at 100 percent of the present range.

+

VARIABLE - NOTE
When you change a source value, source autoranging is automatically turned off and remains off until you re-enable it.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13629.htm b/WebHelpDocs/2601B-PULSE/13629.htm new file mode 100644 index 0000000..aef55a0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13629.htm @@ -0,0 +1,48 @@ + + + + + Overview + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Overview

+

Reading buffers capture measurements, ranges, instrument status, and output state of the Keithley Instruments 2601B-PULSE. The 2601B-PULSE has two default reading buffers. In addition to the default buffers, you can create user-defined reading buffers. You can use the reading buffers to acquire readings.

+

You can access reading buffers from the front panel or over the remote command interface.

+

The default reading buffers can store can store over 60,000 readings if you enable the options for timestamps and source values. To store over 140,000 readings internally, you can disable the timestamps and source values.

+

You can save reading buffers to internal nonvolatile memory in the instrument or to a USB flash drive.

+

Once you save the reading buffers to a USB flash drive, insert the USB flash drive into the USB port on your computer to view the data in any compatible data analysis application or to transfer the data from the USB flash drive to your computer.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13811.htm b/WebHelpDocs/2601B-PULSE/13811.htm new file mode 100644 index 0000000..08f3ab4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13811.htm @@ -0,0 +1,72 @@ + + + + + Functions + + + + + + + + + +
+

Previous Icon

+

Next Icon

+
Functions
+

Function-based commands control actions or activities. A function-based command performs an immediate action on the instrument.

+

Each function consists of a function name followed by a set of parentheses ( ). You should only include information in the parentheses if the function takes a parameter. If the function takes one or more parameters, they are placed between the parentheses and separated by commas.

+

Example 1

+

+ + + + + + +

beeper.beep(0.5, 2400)

+

delay(0.250)

+

beeper.beep(0.5, 2400)

+

Emit a double-beep at 2400 Hz. The sequence is 0.5 s on, 0.25 s off, 0.5 s on.

+
+

Example 2

+

You can use the results of a function-based command directly or assign the results to variables for later access. The following code defines x and prints it.

+

+ + + + + + +

x = math.abs(-100)

+

print(x)

+

Output:

+

100

+
+

+ + + + +
+

See also

Controlling the instrument by sending individual command messages

Attributes

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13933.htm b/WebHelpDocs/2601B-PULSE/13933.htm new file mode 100644 index 0000000..f67ca88 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13933.htm @@ -0,0 +1,94 @@ + + + + + reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

reset()

+

This function resets commands to their default settings.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

reset()

+

reset(system)

+

+ + + + + + +

system

+

What to reset:

+
  • true: If the node is the master, the entire system is reset (default)
  • false: Only the local group is reset
+

Details

+

The reset() command in its simplest form resets the entire TSP-enabled system, including the controlling node and all subordinate nodes.

+

If you want to reset a specific instrument, use either the localnode.reset() or node[X].reset() command. Use the localnode.reset() command for the local instrument. Use the node[X].reset() command to reset an instrument on a subordinate node.

+

You can only reset the entire system using reset(true) if the node is the master. If the node is not the master node, executing this command generates an error.

+

Example

+

+ + + + + + +

reset(true)

+

If the node is the master node, the entire system is reset; if the node is not the master node, an error is generated.

+
+

Also see

+

localnode.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13943.htm b/WebHelpDocs/2601B-PULSE/13943.htm new file mode 100644 index 0000000..a9f8249 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13943.htm @@ -0,0 +1,98 @@ + + + + + settime() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

settime()

+

This function sets the real-time clock (sets present time of the system).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

settime(time)

+

+ + + + + + +

time

+

The time in seconds since January 1, 1970 UTC

+
+

Details

+

This function sets the date and time of the instrument based on the time parameter (specified in UTC time). UTC time is specified as the number of seconds since Jan 1, 1970, UTC. You can use UTC time from a local time specification, or you can use UTC time from another source (for example, your computer).

+

Example

+

+ + + + + + +

systemTime = os.time({year = 2020,

+

month = 3,

+

day = 31,

+

hour = 14,

+

min = 25})

+

settime(systemTime)

+

Sets the date and time to Mar 31, 2020 at 2:25 pm.

+
+

Also see

+

gettimezone()

+

os.time()

+

settimezone()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13949.htm b/WebHelpDocs/2601B-PULSE/13949.htm new file mode 100644 index 0000000..5d3f0aa --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13949.htm @@ -0,0 +1,93 @@ + + + + + delay() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

delay()

+

This function delays the execution of the commands that follow it.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

delay(seconds)

+

+ + + + + + +

seconds

+

The number of seconds to delay (0 to 100 ks)

+
+

Details

+

The instrument delays execution of the commands for at least the specified number of seconds and fractional seconds. However, the processing time may cause the instrument to delay 5 μs to 10 μs (typical) more than the requested delay.

+

Example

+

+ + + + + + +

beeper.beep(0.5, 2400)

+

delay(0.250)

+

beeper.beep(0.5, 2400)

+

Emit a double-beep at 2400 Hz. The sequence is 0.5 s on, 0.25 s off, 0.5 s on.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13986.htm b/WebHelpDocs/2601B-PULSE/13986.htm new file mode 100644 index 0000000..0e666bc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13986.htm @@ -0,0 +1,119 @@ + + + + + waitcomplete() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

waitcomplete()

+

This function waits for all previously started overlapped commands to complete.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

waitcomplete()

+

waitcomplete(group)

+

+ + + + + + +

group

+

Specifies which TSP-Link group on which to wait

+
+

Details

+

There are two types of instrument commands:

+
  • Overlapped commands: Commands that allow the execution of subsequent commands while instrument operations of the overlapped command are still in progress.
  • Sequential commands: Commands whose operations must finish before the next command is executed.

The waitcomplete() command suspends the execution of commands until the instrument operations of all previous overlapped commands are finished. This command is not needed for sequential commands.

+

A group number may only be specified when this node is the master node.

+

If no group is specified, the local group is used.

+

If zero (0) is specified for the group, this function waits for all nodes in the system.

+

VARIABLE - NOTE
Any nodes that are not assigned to a group (group number is 0) are part of the master node's group.

+

Example 1

+

+ + + + + + +

waitcomplete()

+

Waits for all nodes in the local group.

+
+

Example 2

+

+ + + + + + +

waitcomplete(G)

+

Waits for all nodes in group G.

+
+

Example 3

+

+ + + + + + +

waitcomplete(0)

+

Waits for all nodes on the TSP-Link network.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13987.htm b/WebHelpDocs/2601B-PULSE/13987.htm new file mode 100644 index 0000000..a0bbec0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13987.htm @@ -0,0 +1,111 @@ + + + + + userstring.add() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

userstring.add()

+

This function adds a user-defined string to nonvolatile memory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

userstring.add("name", "value")

+

+ + + + + + + + + + +

name

+

The name of the string; the key of the key-value pair

+

value

+

The string to associate with name; the value of the key-value pair

+
+

Details

+

This function associates the string value with the string name and stores this key-value pair in nonvolatile memory.

+

Use the userstring.get() function to retrieve the value associated with the specified name.

+

You can use the userstring functions to store custom, instrument-specific information in the instrument, such as department number, asset number, or manufacturing plant location.

+

Example

+

+ + + + + + +

userstring.add("assetnumber", "236")

+

userstring.add("product", "Widgets")

+

userstring.add("contact", "John Doe")

+

for name in userstring.catalog() do

+

print(name .. " = " ..

+

userstring.get(name))

+

end

+

Stores user-defined strings in nonvolatile memory and recalls them from the instrument using a for loop.

+

Example output:

+

assetnumber = 236

+

contact = John Doe

+

product = Widgets

+
+

Also see

+

userstring.catalog()

+

userstring.delete()

+

userstring.get()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13988.htm b/WebHelpDocs/2601B-PULSE/13988.htm new file mode 100644 index 0000000..4ee4513 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13988.htm @@ -0,0 +1,123 @@ + + + + + userstring.catalog() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

userstring.catalog()

+

This function creates an iterator for the user-defined string catalog.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

for name in userstring.catalog() do body end

+

+ + + + + + + + + + +

name

+

The name of the string; the key of the key-value pair

+

body

+

Code to execute in the body of the for loop

+
+

Details

+

The catalog provides access for user-defined string pairs, allowing you to manipulate all the key-value pairs in nonvolatile memory. The entries are enumerated in no particular order.

+

Example 1

+

+ + + + + + +

for name in userstring.catalog() do

+

userstring.delete(name)

+

end

+

Deletes all user-defined strings in nonvolatile memory.

+
+

Example 2

+

+ + + + + + +

userstring.add("assetnumber", "236")

+

userstring.add("product", "Widgets")

+

userstring.add("contact", "John Doe")

+

for name in userstring.catalog() do

+

print(name .. " = " ..

+

userstring.get(name))

+

end

+

Prints all userstring key-value pairs.

+

Output:

+

product = Widgets

+

assetnumber = 236

+

contact = John Doe

+

Notice the key-value pairs are not listed in the order they were added.

+
+

Also see

+

userstring.add()

+

userstring.delete()

+

userstring.get()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13989.htm b/WebHelpDocs/2601B-PULSE/13989.htm new file mode 100644 index 0000000..80d18e5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13989.htm @@ -0,0 +1,95 @@ + + + + + userstring.delete() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

userstring.delete()

+

This function deletes a user-defined string from nonvolatile memory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

userstring.delete("name")

+

+ + + + + + +

name

+

The name (key) of the key-value pair of the user-defined string to delete

+
+

Details

+

This function deletes the string that is associated with name from nonvolatile memory.

+

Example

+

+ + + + + + +

userstring.delete("assetnumber")

+

userstring.delete("product")

+

userstring.delete("contact")

+

Deletes the user-defined strings associated with the assetnumber, product, and contact names.

+
+

Also see

+

userstring.add()

+

userstring.catalog()

+

userstring.get()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/13990.htm b/WebHelpDocs/2601B-PULSE/13990.htm new file mode 100644 index 0000000..126efaa --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/13990.htm @@ -0,0 +1,107 @@ + + + + + userstring.get() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

userstring.get()

+

This function retrieves a user-defined string from nonvolatile memory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

value = userstring.get("name")

+

+ + + + + + + + + + +

value

+

The value of the user-defined string key-value pair

+

name

+

The name (key) of the user-defined string

+
+

Details

+

This function retrieves the string that is associated with name from nonvolatile memory.

+

Example

+

+ + + + + + + + +

userstring.add("assetnumber", "236")

+

value = userstring.get("assetnumber")

+

print(value)

+

Create the user-defined string assetnumber, set to a value of 236.

+

Read the value associated with the user-defined string named assetnumber.

+

Store it in a variable called value, then print the variable value.

+

Output:

+

236

+
+

Also see

+

userstring.add()

+

userstring.catalog()

+

userstring.delete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14072.htm b/WebHelpDocs/2601B-PULSE/14072.htm new file mode 100644 index 0000000..978e350 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14072.htm @@ -0,0 +1,59 @@ + + + + + TSP-Net + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP-Net

+

The TSP-Net module provides a simple socket-like programming interface to Test Script Processor (TSP®) enabled instruments.

+

tspnet.clear()

+

tspnet.connect()

+

tspnet.disconnect()

+

tspnet.execute()

+

tspnet.idn()

+

tspnet.read()

+

tspnet.readavailable()

+

tspnet.reset()

+

tspnet.termination()

+

tspnet.timeout

+

tspnet.tsp.abort()

+

tspnet.tsp.abortonconnect

+

tspnet.tsp.rbtablecopy()

+

tspnet.tsp.runscript()

+

tspnet.write()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14073.htm b/WebHelpDocs/2601B-PULSE/14073.htm new file mode 100644 index 0000000..b20df72 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14073.htm @@ -0,0 +1,105 @@ + + + + + tspnet.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.clear()

+

This function clears any pending output data from the instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

tspnet.clear(connectionID)

+

+ + + + + + +

connectionID

+

The connection ID returned from tspnet.connect()

+
+

Details

+

This function clears any pending output data from the device. No data is returned to the caller and no data is processed.

+

Example

+

+ + + + + + +

tspnet.write(testdevice, "print([[hello]])")

+

print(tspnet.readavailable(testdevice))

+

 

+

 

+

 

+

tspnet.clear(testdevice)

+

print(tspnet.readavailable(testdevice))

+

Write data to a device, then print how much is available.

+

Output:

+

6.00000e+00

+

 

+

Clear data and print how much data is available again.

+

Output:

+

0.00000e+00

+
+

Also see

+

tspnet.connect()

+

tspnet.readavailable()

+

tspnet.write()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14074.htm b/WebHelpDocs/2601B-PULSE/14074.htm new file mode 100644 index 0000000..dd3cfe3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14074.htm @@ -0,0 +1,141 @@ + + + + + tspnet.connect() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.connect()

+

This function establishes a network connection with another LAN instrument or device through the LAN interface.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

connectionID = tspnet.connect("ipAddress")

+

connectionID = tspnet.connect("ipAddress", portNumber, "initString")

+

+ + + + + + + + + + + + + + + + + + +

connectionID

+

The connection ID to be used as a handle in all other tspnet function calls

+

ipAddress

+

IP address to which to connect in a string

+

portNumber

+

Port number (default 5025)

+

initString

+

Initialization string to send to ipAddress

+
+

Details

+

This command connects a device to another device through the LAN interface. If the portNumber is 23, the interface uses the Telnet protocol and sets appropriate termination characters to communicate with the device.

+

If a portNumber and initString are provided, it is assumed that the remote device is not TSP-enabled. The 2601B-PULSE does not perform any extra processing, prompt handling, error handling, or sending of commands. In addition, the tspnet.tsp.* commands cannot be used on devices that are not TSP-enabled.

+

If neither a portNumber nor an initString is provided, the remote device is assumed to be a Keithley Instruments TSP-enabled device. Depending on the state of the tspnet.tsp.abortonconnect attribute, the 2601B-PULSE sends an abort command to the remote device on connection.

+

The 2601B-PULSE also enables TSP prompts on the remote device and error management. The 2601B-PULSE places remote errors from the TSP-enabled device in its own error queue and prefaces these errors with Remote Error, followed by an error description.

+

Do not manually change either the prompt functionality (localnode.prompts) or show errors by changing localnode.showerrors on the remote TSP-enabled device. If you do this, subsequent tspnet.tsp.* commands using the connection may fail.

+

You can simultaneously connect to a maximum of 32 remote devices.

+

Example 1

+

+ + + + + + + + +

instrumentID = tspnet.connect("192.0.2.1")

+

if instrumentID then

+

-- Use instrumentID as needed here

+

tspnet.disconnect(instrumentID)

+

end

+

Connect to a TSP-enabled device.

+
+

Example 2

+

+ + + + + + + + +

instrumentID = tspnet.connect("192.0.2.1", 1394, "*rst\r\n")

+

if instrumentID then

+

-- Use instrumentID as needed here

+

tspnet.disconnect(instrumentID)

+

end

+

Connect to a device that is not TSP-enabled.

+
+

Also see

+

localnode.prompts

+

localnode.showerrors

+

tspnet.tsp.abortonconnect

+

tspnet.disconnect()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14076.htm b/WebHelpDocs/2601B-PULSE/14076.htm new file mode 100644 index 0000000..c85ac73 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14076.htm @@ -0,0 +1,96 @@ + + + + + tspnet.disconnect() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.disconnect()

+

This function disconnects a specified TSP-Net session.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

tspnet.disconnect(connectionID)

+

+ + + + + + +

connectionID

+

The connection ID returned from tspnet.connect()

+
+

Details

+

This function disconnects the two devices by closing the connection. The connectionID is the session handle returned by tspnet.connect().

+

For TSP-enabled devices, this aborts any remotely running commands or scripts.

+

Example

+

+ + + + + + +

testID = tspnet.connect("192.0.2.0")

+

-- Use the connection

+

tspnet.disconnect(testID)

+

Create a TSP-Net session.

+

 

+

Close the session.

+
+

Also see

+

tspnet.connect()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14077.htm b/WebHelpDocs/2601B-PULSE/14077.htm new file mode 100644 index 0000000..0914c26 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14077.htm @@ -0,0 +1,153 @@ + + + + + tspnet.execute() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.execute()

+

This function sends a command string to the remote device.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

tspnet.execute("connectionID", "commandString")

+

value1 = tspnet.execute("connectionID", "commandString", formatString)

+

value1, value2 = tspnet.execute("connectionID", "commandString", formatString)

+

value1, ..., valueN = tspnet.execute("connectionID", "commandString", formatString)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

connectionID

+

The connection ID returned from tspnet.connect()

+

commandString

+

The command to send to the remote device

+

value1

+

The first value decoded from the response message

+

value2

+

The second value decoded from the response message

+

valueN

+

The Nth value decoded from the response message; there is one return value for each format specifier in the format string

+

...

+

One or more values separated with commas

+

formatString

+

Format string for the output

+
+

Details

+

This command sends a command string to the remote instrument. A termination is added to the command string when it is sent to the remote instrument (tspnet.termination()). You can also specify a format string, which causes the command to wait for a response from the remote instrument. The 2601B-PULSE decodes the response message according to the format specified in the format string and returns the message as return values from the function (see tspnet.read() for format specifiers).

+

When this command is sent to a TSP-enabled instrument, the 2601B-PULSE suspends operation until a timeout error is generated or until the instrument responds. The TSP prompt from the remote instrument is read and discarded. The 2601B-PULSE places any remotely generated errors into its error queue. When the optional format string is not specified, this command is equivalent to tspnet.write(), except that a termination is automatically added to the end of the command.

+

Example 1

+

+ + + + + + + + +

tspnet.execute(instrumentID, "runScript()")

+

Command the remote device to run a script named runScript.

+
+

Example 2

+

+ + + + + + + + +

tspnet.timeout = 5

+

id_instr = tspnet.connect("192.0.2.23", 23, "*rst\r\n")

+

tspnet.termination(id_instr, tspnet.TERM_CRLF)

+

tspnet.execute(id_instr, "*idn?")

+

print("tspnet.execute returns:", tspnet.read(id_instr))

+

Print the *idn? string from the remote device.

+
+

Also see

+

tspnet.connect()

+

tspnet.read()

+

tspnet.termination()

+

tspnet.write()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14078.htm b/WebHelpDocs/2601B-PULSE/14078.htm new file mode 100644 index 0000000..d44e804 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14078.htm @@ -0,0 +1,102 @@ + + + + + tspnet.idn() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.idn()

+

This function retrieves the response of the remote device to *IDN?.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

idnString = tspnet.idn(connectionID)

+

+ + + + + + + + + + +

idnString

+

The returned *IDN? string

+

connectionID

+

The connection ID returned from tspnet.connect()

+
+

Details

+

This function retrieves the response of the remote device to *IDN?.

+

Example

+

+

+ + + + + + +

deviceID = tspnet.connect("192.0.2.1")

+

print(tspnet.idn(deviceID))

+

tspnet.disconnect(deviceID)

+

Assume the instrument is at IP address 192.0.2.1.

+

The output that is produced when you connect to the instrument and read the identification string may appear as:

+

Keithley Instruments,Model 2601B-PULSE, 1398687, 1.0.0

+
+

Also see

+

tspnet.connect()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14079.htm b/WebHelpDocs/2601B-PULSE/14079.htm new file mode 100644 index 0000000..c6d3bc2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14079.htm @@ -0,0 +1,164 @@ + + + + + tspnet.read() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.read()

+

This function reads data from a remote device.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

value1 = tspnet.read(connectionID)

+

value1 = tspnet.read(connectionID, formatString)

+

value1, value2 = tspnet.read(connectionID, formatString)

+

value1, ..., valueN = tspnet.read(connectionID, formatString)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

value1

+

The first value decoded from the response message

+

value2

+

The second value decoded from the response message

+

valueN

+

The nth value decoded from the response message; there is one return value for each format specifier in the format string

+

...

+

One or more values separated with commas

+

connectionID

+

The connection ID returned from tspnet.connect()

+

formatString

+

Format string for the output, maximum of 10 specifiers

+
+

Details

+

This command reads available data from the remote instrument and returns responses for the specified number of arguments.

+

The format string can contain the following specifiers:

+

+ + + + + + + + + + + + + + + + + + +

%[width]s

+

Read data until the specified length

+

%[max width]t

+

Read data until the specified length or until punctuation is found, whichever comes first

+

%[max width]n

+

Read data until a newline or carriage return

+

%d

+

Read a number (delimited by punctuation)

+
+

A maximum of 10 format specifiers can be used for a maximum of 10 return values.

+

If formatString is not provided, the command returns a string that contains the data until a new line is reached. If no data is available, the 2601B-PULSE pauses operation until the requested data is available or until a timeout error is generated. Use tspnet.timeout to specify the timeout period.

+

When the 2601B-PULSE reads from a TSP-enabled remote instrument, the 2601B-PULSE removes Test Script Processor (TSP®) prompts and places any errors it receives from the remote instrument into its own error queue. The 2601B-PULSE prefaces errors from the remote device with "Remote Error," followed by the error number and error description.

+

Example

+

+ + + + + + + + +

tspnet.write(deviceID, "*idn?\r\n")

+

 

+

print("write/read returns:", tspnet.read(deviceID))

+

Send the "*idn?\r\n" message to the instrument connected as deviceID.

+

Display the response that is read from deviceID (based on the *idn? message).

+
+

Also see

+

tspnet.connect()

+

tspnet.readavailable()

+

tspnet.timeout

+

tspnet.write()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14080.htm b/WebHelpDocs/2601B-PULSE/14080.htm new file mode 100644 index 0000000..f6cdd52 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14080.htm @@ -0,0 +1,108 @@ + + + + + tspnet.readavailable() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.readavailable()

+

This function checks to see if data is available from the remote device.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

bytesAvailable = tspnet.readavailable(connectionID)

+

+ + + + + + + + + + +

bytesAvailable

+

The number of bytes available to be read from the connection

+

connectionID

+

The connection ID returned from tspnet.connect()

+
+

Details

+

This command checks to see if any output data is available from the device. No data is read from the instrument. This allows TSP scripts to continue to run without waiting on a remote command to finish.

+

Example

+

+ + + + + + + + +

ID = tspnet.connect("192.0.2.1")

+

tspnet.write(ID, "*idn?\r\n")

+

 

+

repeat bytes = tspnet.readavailable(ID) until bytes > 0

+

 

+

print(tspnet.read(ID))

+

tspnet.disconnect(ID)

+

Send commands that will create data.

+

 

+

Wait for data to be available.

+
+

Also see

+

tspnet.connect()

+

tspnet.read()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14081.htm b/WebHelpDocs/2601B-PULSE/14081.htm new file mode 100644 index 0000000..1c3dbf1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14081.htm @@ -0,0 +1,70 @@ + + + + + tspnet.reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.reset()

+

This function disconnects all TSP-Net sessions.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

tspnet.reset()

+

Details

+

This command disconnects all remote instruments connected through TSP-Net. For TSP-enabled devices, this causes any commands or scripts running remotely to be terminated.

+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14082.htm b/WebHelpDocs/2601B-PULSE/14082.htm new file mode 100644 index 0000000..0b379d0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14082.htm @@ -0,0 +1,110 @@ + + + + + tspnet.termination() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.termination()

+

This function sets the device line termination sequence.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

type = tspnet.termination(connectionID)

+

type = tspnet.termination(connectionID, termSequence)

+

+ + + + + + + + + + + + + + +

type

+

An enumerated value indicating the termination type:

+
  • 1 or tspnet.TERM_LF
  • 4 or tspnet.TERM_CR
  • 2 or tspnet.TERM_CRLF
  • 3 or tspnet.TERM_LFCR

connectionID

+

The connection ID returned from tspnet.connect()

+

termSequence

+

The termination sequence

+
+

Details

+

This function sets and gets the termination character sequence that is used to indicate the end of a line for a TSP-Net connection.

+

Using the termSequence parameter sets the termination sequence. The present termination sequence is always returned.

+

For the termSequence parameter, use the same values listed in the table above for type. There are four possible combinations, all of which are made up of line feeds (LF or 0x10) and carriage returns (CR or 0x13). For TSP-enabled devices, the default is tspnet.TERM_LF. For devices that are not TSP-enabled, the default is tspnet.TERM_CRLF.

+

Example

+

+ + + + + + +

deviceID = tspnet.connect("192.0.2.1")

+

if deviceID then

+

tspnet.termination(deviceID, tspnet.TERM_LF)

+

end

+

Sets termination type for IP address 192.0.2.1 to TERM_LF.

+
+

Also see

+

tspnet.connect()

+

tspnet.disconnect()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14084.htm b/WebHelpDocs/2601B-PULSE/14084.htm new file mode 100644 index 0000000..00d0350 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14084.htm @@ -0,0 +1,96 @@ + + + + + tspnet.timeout + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.timeout

+

This attribute sets the timeout value for the tspnet.connect(), tspnet.execute(), and tspnet.read() commands.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

No

+

Instrument reset
Recall setup

+

Not saved

+

20.0 (20 s)

+
+

+

Usage

+

value = tspnet.timeout

+

tspnet.timeout = value

+

+ + + + + + +

value

+

The timeout duration in seconds (1 ms to 30.0 s)

+
+

Details

+

This attribute sets the amount of time the tspnet.connect(), tspnet.execute(), and tspnet.read() commands will wait for a response.

+

The time is specified in seconds. The timeout may be specified to millisecond resolution but is only accurate to the nearest 10 ms.

+

Example

+

+ + + + + + +

tspnet.timeout = 2.0

+

Sets the timeout duration to 2 s.

+
+

Also see

+

tspnet.connect()

+

tspnet.execute()

+

tspnet.read()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14085.htm b/WebHelpDocs/2601B-PULSE/14085.htm new file mode 100644 index 0000000..e804e30 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14085.htm @@ -0,0 +1,92 @@ + + + + + tspnet.tsp.abort() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.tsp.abort()

+

This function causes the TSP-enabled instrument to stop executing any of the commands that were sent to it.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

tspnet.tsp.abort(connectionID)

+

+ + + + + + +

connectionID

+

Integer value used as a handle for other tspnet commands

+
+

Details

+

This function is appropriate only for TSP-enabled instruments.

+

Sends an abort command to the remote instrument.

+

Example

+

+ + + + + + +

tspnet.tsp.abort(testConnection)

+

Stops remote instrument execution on testConnection.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14086.htm b/WebHelpDocs/2601B-PULSE/14086.htm new file mode 100644 index 0000000..c353c7e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14086.htm @@ -0,0 +1,92 @@ + + + + + tspnet.tsp.abortonconnect + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.tsp.abortonconnect

+

This attribute contains the setting for abort on connect to a TSP-enabled instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

No

+

Instrument reset
Recall setup

+

Not saved

+

1 (enable)

+
+

Usage

+

tspnet.tsp.abortonconnect = value

+

value = tspnet.tsp.abortonconnect

+

+ + + + + + +

value

+
  • Enable: 1
  • Disable: 0
+

Details

+

This setting determines if the instrument sends an abort message when it attempts to connect to a TSP-enabled instrument using the tspnet.connect() function.

+

When you send the abort command on an interface, it causes any other active interface on that instrument to close. If you do not send an abort command (or if tspnet.tsp.abortonconnect is set to 0) and another interface is active, connecting to a TSP-enabled remote instrument results in a connection. However, the instrument will not respond to subsequent reads or executes because control of the instrument is not obtained until an abort command has been sent.

+

Example

+

+ + + + + + +

tspnet.tsp.abortonconnect = 0

+

Configure the instrument so that it does not send an abort command when connecting to a TSP-enabled instrument.

+
+

Also see

+

tspnet.connect()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14089.htm b/WebHelpDocs/2601B-PULSE/14089.htm new file mode 100644 index 0000000..a451ecc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14089.htm @@ -0,0 +1,100 @@ + + + + + tspnet.write() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.write()

+

This function writes a string to the remote instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

tspnet.write(connectionID, "inputString")

+

+ + + + + + + + + + +

connectionID

+

The connection ID returned from tspnet.connect()

+

inputString

+

The string to be written

+
+

Details

+

The tspnet.write() function sends inputString to the remote instrument. It does not wait for command completion on the remote instrument.

+

The 2601B-PULSE sends inputString to the remote instrument exactly as indicated. The inputString must contain any necessary new lines, termination, or other syntax elements needed to complete properly.

+

Because tspnet.write() does not process output from the remote instrument, do not send commands that generate too much output without processing the output. This command can stop executing if there is too much unprocessed output from previous commands.

+

Example

+

+ + + + + + +

tspnet.write(myID, "runscript()\r\n")

+

Commands the remote instrument to execute a command or script named runscript() on a remote device identified in the system as myID.

+
+

Also see

+

tspnet.connect()

+

tspnet.read()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14090.htm b/WebHelpDocs/2601B-PULSE/14090.htm new file mode 100644 index 0000000..4ce3624 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14090.htm @@ -0,0 +1,124 @@ + + + + + tspnet.tsp.rbtablecopy() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.tsp.rbtablecopy()

+

This function copies a reading buffer synchronous table from a remote instrument to a TSP-enabled instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

table = tspnet.tsp.rbtablecopy(connectionID, "name")

+

table = tspnet.tsp.rbtablecopy(connectionID, "name", startIndex, endIndex)

+

+ + + + + + + + + + + + + + + + + + + + + + +

table

+

A copy of the synchronous table or a string

+

connectionID

+

Integer value used as a handle for other tspnet commands

+

name

+

The full name of the reading buffer name and synchronous table to copy

+

startIndex

+

Integer start value

+

endIndex

+

Integer end value

+
+

Details

+

This function is only appropriate for TSP-enabled instruments.

+

This function reads the data from a reading buffer on a remote instrument and returns an array of numbers or a string representing the data. The startIndex and endIndex parameters specify the portion of the reading buffer to read. If no index is specified, the entire buffer is copied.

+

The function returns a table if the table is an array of numbers; otherwise a comma-delimited string is returned.

+

This command is limited to transferring 50,000 readings at a time.

+

Example

+

+ + + + + + +

t = tspnet.tsp.rbtablecopy(testConnection,

+

"testRemotebuffername.readings", 1, 3)

+

print(t[1], t[2], t[3])

+

Copy the specified readings table for buffer items 1 through 3, then display the first three readings. Example output:

+

4.56534e-01

+

4.52675e-01

+

4.57535e-01

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14126.htm b/WebHelpDocs/2601B-PULSE/14126.htm new file mode 100644 index 0000000..7c1f678 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14126.htm @@ -0,0 +1,90 @@ + + + + + Status model + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Status model

+

The status model is a set of status registers and queues. You can use the following commands to manipulate and monitor these registers and queues to view and control various instrument events.

+

status.condition

+

status.measurement.*

+

status.measurement.buffer_available.*

+

status.measurement.current_limit.*

+

status.measurement.instrument.*

+

status.measurement.instrument.smua.*

+

status.measurement.reading_overflow.*

+

status.measurement.voltage_limit.*

+

status.node_enable

+

status.node_event

+

status.operation.*

+

status.operation.calibrating.*

+

status.operation.instrument.*

+

status.operation.instrument.digio.*

+

status.operation.instrument.digio.trigger_overrun.*

+

status.operation.instrument.lan.*

+

status.operation.instrument.lan.trigger_overrun.*

+

status.operation.instrument.smua.*

+

status.operation.instrument.smua.trigger_overrrun.*

+

status.operation.instrument.trigger_blender.*

+

status.operation.instrument.trigger_blender.trigger_overrun.*

+

status.operation.instrument.trigger_timer.*

+

status.operation.instrument.trigger_timer.trigger_overrun.*

+

status.operation.instrument.tsplink.*

+

status.operation.instrument.tsplink.trigger_overrun.*

+

status.operation.measuring.*

+

status.operation.remote.*

+

status.operation.sweeping.*

+

status.operation.trigger_overrun.*

+

status.operation.user.*

+

status.questionable.*

+

status.questionable.calibration.*

+

status.questionable.instrument.*

+

status.questionable.instrument.smua.*

+

status.questionable.over_temperature.*

+

status.questionable.unstable_output.*

+

status.request_enable

+

status.request_event

+

status.reset()

+

status.standard.*

+

status.system.*

+

status.system2.*

+

status.system3.*

+

status.system4.*

+

status.system5.*

+

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14127.htm b/WebHelpDocs/2601B-PULSE/14127.htm new file mode 100644 index 0000000..7eb2da5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14127.htm @@ -0,0 +1,46 @@ + + + + + Beeper control + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Beeper control

+

The beeper commands allow you to enable or disable and sound the instrument beeper.

+

beeper.beep()

+

beeper.enable

+ + + + +
+

See also

About TSP commands

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14129.htm b/WebHelpDocs/2601B-PULSE/14129.htm new file mode 100644 index 0000000..3b48b1d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14129.htm @@ -0,0 +1,95 @@ + + + + + LAN and LXI + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

LAN and LXI

+

The LAN commands have options that allow you to review and configure network settings.

+

The lan.config.* commands allow you to configure LAN settings over the remote interface. Note that you must send lan.applysettings() for the configuration settings to take effect.

+

The lan.status.* commands help you determine the status of the LAN.

+

The lan.trigger[N].* commands allow you to set up and assert trigger events that are sent over the LAN.

+

Other LAN commands allow you to reset the LAN, restore defaults, check LXI domain information, and enable or disable the Nagle algorithm.

+

lan.applysettings()

+

lan.autoconnect

+

lan.config.dns.address[N]

+

lan.config.dns.domain

+

lan.config.dns.dynamic

+

lan.config.dns.hostname

+

lan.config.dns.verify

+

lan.config.duplex

+

lan.config.gateway

+

lan.config.ipaddress

+

lan.config.method

+

lan.config.speed

+

lan.config.subnetmask

+

lan.linktimeout

+

lan.lxidomain

+

lan.nagle

+

lan.reset()

+

lan.restoredefaults()

+

lan.status.dns.address[N]

+

lan.status.dns.name

+

lan.status.duplex

+

lan.status.gateway

+

lan.status.ipaddress

+

lan.status.macaddress

+

lan.status.port.dst

+

lan.status.port.rawsocket

+

lan.status.port.telnet

+

lan.status.port.vxi11

+

lan.status.speed

+

lan.status.subnetmask

+

lan.timedwait

+

lan.trigger[N].assert()

+

lan.trigger[N].clear()

+

lan.trigger[N].connect()

+

lan.trigger[N].connected

+

lan.trigger[N].disconnect()

+

lan.trigger[N].EVENT_ID

+

lan.trigger[N].ipaddress

+

lan.trigger[N].mode

+

lan.trigger[N].overrun

+

lan.trigger[N].protocol

+

lan.trigger[N].pseudostate

+

lan.trigger[N].stimulus

+

lan.trigger[N].wait()

+

localnode.description

+

localnode.password

+

localnode.passwordmode

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14435.htm b/WebHelpDocs/2601B-PULSE/14435.htm new file mode 100644 index 0000000..ab13628 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14435.htm @@ -0,0 +1,95 @@ + + + + + beeper.enable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

beeper.enable

+

This command allows you to turn the beeper on or off.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Recall setup
Instrument reset

+

Saved setup

+

1 (beeper.ON)

+
+

Usage

+

state = beeper.enable

+

beeper.enable = state

+

+

+ + + + + + +

state

+

Disable the beeper: beeper.OFF or 0

+

Enable the beeper: beeper.ON or 1

+
+

Details

+

This command enables or disables the beeper. When enabled, a beep signals that a front-panel key has been pressed. Disabling the beeper also disables front-panel key clicks.

+

Example

+

+ + + + + + +

beeper.enable = beeper.ON

+

beeper.beep(2, 2400)

+

Enables the beeper and generates a two-second, 2400 Hz tone.

+
+

Also see

+

beeper.beep()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14632.htm b/WebHelpDocs/2601B-PULSE/14632.htm new file mode 100644 index 0000000..0eedd1d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14632.htm @@ -0,0 +1,109 @@ + + + + + bit.bitand() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.bitand()

+

This function performs a bitwise logical AND operation on two numbers.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.bitand(value1, value2)

+

+ + + + + + + + + + + + + + +

result

+

Result of the logical AND operation

+

value1

+

Operand for the logical AND operation

+

value2

+

Operand for the logical AND operation

+
+

Details

+

Any fractional parts of value1 and value2 are truncated to form integers. The returned result is also an integer.

+

Example

+

+ + + + + + +

testResult = bit.bitand(10, 9)

+

 

+

print(testResult)

+

Performs a logical AND operation on decimal 10 (binary 1010) with decimal 9 (binary 1001), which returns a value of decimal 8 (binary 1000).

+

Output:

+

8.00000e+00

+
+

Also see

+

Bit manipulation and logic operations

+

bit.bitor()

+

bit.bitxor()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14634.htm b/WebHelpDocs/2601B-PULSE/14634.htm new file mode 100644 index 0000000..cd0c9a0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14634.htm @@ -0,0 +1,109 @@ + + + + + bit.bitor() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.bitor()

+

This function performs a bitwise logical OR operation on two numbers.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.bitor(value1, value2)

+

+ + + + + + + + + + + + + + +

result

+

Result of the logical OR operation

+

value1

+

Operand for the logical OR operation

+

value2

+

Operand for the logical OR operation

+
+

Details

+

Any fractional parts of value1 and value2 are truncated to make them integers. The returned result is also an integer.

+

Example

+

+ + + + + + +

testResult = bit.bitor(10, 9)

+

 

+

print(testResult)

+

Performs a bitwise logical OR operation on decimal 10 (binary 1010) with decimal 9 (binary 1001), which returns a value of decimal 11 (binary 1011).

+

Output:

+

1.10000e+01

+
+

Also see

+

Bit manipulation and logic operations

+

bit.bitand()

+

bit.bitxor()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14635.htm b/WebHelpDocs/2601B-PULSE/14635.htm new file mode 100644 index 0000000..6dbd699 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14635.htm @@ -0,0 +1,109 @@ + + + + + bit.bitxor() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.bitxor()

+

This function performs a bitwise logical XOR (exclusive OR) operation on two numbers.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.bitxor(value1, value2)

+

+ + + + + + + + + + + + + + +

result

+

Result of the logical XOR operation

+

value1

+

Operand for the logical XOR operation

+

value2

+

Operand for the logical XOR operation

+
+

Details

+

Any fractional parts of value1 and value2 are truncated to make them integers. The returned result is also an integer.

+

Example

+

+ + + + + + +

testResult = bit.bitxor(10, 9)

+

 

+

print(testResult)

+

Performs a logical XOR operation on decimal 10 (binary 1010) with decimal 9 (binary 1001), which returns a value of decimal 3 (binary 0011).

+

Output:

+

3.00000e+00

+
+

Also see

+

Bit manipulation and logic operations

+

bit.bitand()

+

bit.bitor()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14636.htm b/WebHelpDocs/2601B-PULSE/14636.htm new file mode 100644 index 0000000..de3e5e8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14636.htm @@ -0,0 +1,112 @@ + + + + + bit.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.clear()

+

This function clears a bit at a specified index position.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.clear(value, index)

+

+ + + + + + + + + + + + + + +

result

+

Result of the bit manipulation

+

value

+

Specified number

+

index

+

One-based bit position within value to clear (1 to 32)

+
+

Details

+

Any fractional part of value is truncated to make it an integer. The returned result is also an integer.

+

The least significant bit of value is at index position 1; the most significant bit is at index position 32.

+

Example

+

+ + + + + + +

testResult = bit.clear(15, 2)

+

 

+

print(testResult)

+

The binary equivalent of decimal 15 is 1111. If you clear the bit at index position 2, the returned decimal value is 13 (binary 1101).

+

Output:

+

1.30000e+01

+
+

Also see

+

Bit manipulation and logic operations

+

bit.get()

+

bit.set()

+

bit.test()

+

bit.toggle()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14637.htm b/WebHelpDocs/2601B-PULSE/14637.htm new file mode 100644 index 0000000..d4fcaed --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14637.htm @@ -0,0 +1,113 @@ + + + + + bit.get() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.get()

+

This function retrieves the weighted value of a bit at a specified index position.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.get(value, index)

+

+ + + + + + + + + + + + + + +

result

+

Result of the bit manipulation

+

value

+

Specified number

+

index

+

One-based bit position within value to get (1 to 32)

+
+

Details

+

This function returns the value of the bit in value at index. This is the same as returning value with all other bits set to zero (0).

+

The least significant bit of value is at index position 1; the most significant bit is at index position 32.

+

If the indexed bit for the number is set to zero (0), the result will be zero (0).

+

Example

+

+ + + + + + +

testResult = bit.get(10, 4)

+

 

+

print(testResult)

+

The binary equivalent of decimal 10 is 1010. If you get the bit at index position 4, the returned decimal value is 8.

+

Output:

+

8.00000e+00

+
+

Also see

+

Bit manipulation and logic operations

+

bit.clear()

+

bit.set()

+

bit.test()

+

bit.toggle()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14638.htm b/WebHelpDocs/2601B-PULSE/14638.htm new file mode 100644 index 0000000..e488fa0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14638.htm @@ -0,0 +1,121 @@ + + + + + bit.getfield() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.getfield()

+

This function returns a field of bits from the value starting at the specified index position.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.getfield(value, index, width)

+

+ + + + + + + + + + + + + + + + + + +

result

+

Result of the bit manipulation

+

value

+

Specified number

+

index

+

One-based bit position within value to get (1 to 32)

+

width

+

The number of bits to include in the field (1 to 32)

+
+

Details

+

A field of bits is a contiguous group of bits. This function retrieves a field of bits from value starting at index.

+

The index position is the least significant bit of the retrieved field. The number of bits to return is specified by width.

+

The least significant bit of value is at index position 1; the most significant bit is at index position 32.

+

Example

+

+ + + + + + +

myResult = bit.getfield(13, 2, 3)

+

 

+

 

+

 

+

print(myResult)

+

The binary equivalent of decimal 13 is 1101.

+

The field at index position 2 and width 3 consists of the binary bits 110. The returned value is decimal 6 (binary 110).

+

Output:

+

6.00000e+00

+
+

Also see

+

Bit manipulation and logic operations

+

bit.get()

+

bit.set()

+

bit.setfield()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14639.htm b/WebHelpDocs/2601B-PULSE/14639.htm new file mode 100644 index 0000000..6725b60 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14639.htm @@ -0,0 +1,115 @@ + + + + + bit.set() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.set()

+

This function sets a bit at the specified index position.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.set(value, index)

+

+ + + + + + + + + + + + + + +

result

+

Result of the bit manipulation

+

value

+

Specified number

+

index

+

One-based bit position within value to set (1 to 32)

+
+

Details

+

This function returns result, which is value with the indexed bit set. The index must be between 1 and 32.

+

The least significant bit of value is at index position 1; the most significant bit is at index position 32.

+

Any fractional part of value is truncated to make it an integer.

+

Example

+

+ + + + + + +

testResult = bit.set(8, 3)

+

 

+

print(testResult)

+

The binary equivalent of decimal 8 is 1000. If the bit at index position 3 is set to 1, the returned value is decimal 12 (binary 1100).

+

Output:

+

1.20000e+01

+
+

Also see

+

Bit manipulation and logic operations

+

bit.clear()

+

bit.get()

+

bit.getfield()

+

bit.setfield()

+

bit.test()

+

bit.toggle()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14640.htm b/WebHelpDocs/2601B-PULSE/14640.htm new file mode 100644 index 0000000..917db39 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14640.htm @@ -0,0 +1,126 @@ + + + + + bit.setfield() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.setfield()

+

This function overwrites a bit field at a specified index position.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.setfield(value, index, width, fieldValue)

+

+ + + + + + + + + + + + + + + + + + + + + + +

result

+

Result of the bit manipulation

+

value

+

Specified number

+

index

+

One-based bit position in value to set (1 to 32)

+

width

+

The number of bits to include in the field (1 to 32)

+

fieldValue

+

Value to write to the field

+
+

Details

+

This function returns result, which is value with a field of bits overwritten, starting at index. The index specifies the position of the least significant bit of value. The width bits starting at index are set to fieldValue.

+

The least significant bit of value is at index position 1; the most significant bit is at index position 32.

+

Before setting the field of bits, any fractional parts of value and fieldValue are truncated to form integers.

+

If fieldValue is wider than width, the most significant bits of the fieldValue that exceed the width are truncated. For example, if width is 4 bits and the binary value for fieldValue is 11110 (5 bits), the most significant bit of fieldValue is truncated and a binary value of 1110 is used.

+

Example

+

+ + + + + + +

testResult = bit.setfield(15, 2, 3, 5)

+

 

+

 

+

print(testResult)

+

The binary equivalent of decimal 15 is 1111. After overwriting it with a decimal 5 (binary 101) at index position 2, the returned value is decimal 11 (binary 1011).

+

Output:

+

1.10000e+01

+
+

Also see

+

Bit manipulation and logic operations

+

bit.get()

+

bit.set()

+

bit.getfield()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14641.htm b/WebHelpDocs/2601B-PULSE/14641.htm new file mode 100644 index 0000000..37c4a45 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14641.htm @@ -0,0 +1,114 @@ + + + + + bit.test() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.test()

+

This function returns the Boolean value (true or false) of a bit at the specified index position.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.test(value, index)

+

+ + + + + + + + + + + + + + +

result

+

Result of the bit manipulation

+

value

+

Specified number

+

index

+

One-based bit position within value to test (1 to 32)

+
+

Details

+

This function returns result, which is the result of the tested bit.

+

The least significant bit of value is at index position 1; the most significant bit is at index position 32.

+

If the indexed bit for value is 0, result is false. If the bit of value at index is 1, the returned value is true.

+

If index is bigger than the number of bits in value, the result is false.

+

Example

+

+ + + + + + +

testResult = bit.test(10, 4)

+

 

+

print(testResult)

+

The binary equivalent of decimal 10 is 1010. Testing the bit at index position 4 returns a Boolean value of true.

+

Output:

+

true

+
+

Also see

+

Bit manipulation and logic operations

+

bit.clear()

+

bit.get()

+

bit.set()

+

bit.toggle()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14642.htm b/WebHelpDocs/2601B-PULSE/14642.htm new file mode 100644 index 0000000..6ce96c8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14642.htm @@ -0,0 +1,114 @@ + + + + + bit.toggle() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bit.toggle()

+

This function toggles the value of a bit at a specified index position.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

result = bit.toggle(value, index)

+

+ + + + + + + + + + + + + + +

result

+

Result of the bit manipulation

+

value

+

Specified number

+

index

+

One-based bit position within value to toggle (1 to 32)

+
+

Details

+

This function returns result, which is the result of toggling the bit index in value.

+

Any fractional part of value is truncated to make it an integer. The returned value is also an integer.

+

The least significant bit of value is at index position 1; the most significant bit is at index position 32.

+

The indexed bit for value is toggled from 0 to 1, or 1 to 0.

+

Example

+

+ + + + + + +

testResult = bit.toggle(10, 3)

+

 

+

print(testResult)

+

The binary equivalent of decimal 10 is 1010. Toggling the bit at index position 3 returns a decimal value of 14 (binary 1110).

+

Output:

+

1.40000e+01

+
+

Also see

+

Bit manipulation and logic operations

+

bit.clear()

+

bit.get()

+

bit.set()

+

bit.test()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14653.htm b/WebHelpDocs/2601B-PULSE/14653.htm new file mode 100644 index 0000000..a92593f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14653.htm @@ -0,0 +1,51 @@ + + + + + Data queue + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Data queue

+

Use the data queue commands to:

+
  • Share data between test scripts running in parallel
  • Access data from a remote group or a local node on a TSP-Link® network at any time

The data queue in the Test Script Processor (TSP®) scripting engine is first-in, first-out (FIFO).

+

You can access data from the data queue even if a remote group or a node has overlapped operations in process.

+

dataqueue.add()

+

dataqueue.CAPACITY

+

dataqueue.clear()

+

dataqueue.count

+

dataqueue.next()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14654.htm b/WebHelpDocs/2601B-PULSE/14654.htm new file mode 100644 index 0000000..d81fa54 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14654.htm @@ -0,0 +1,127 @@ + + + + + dataqueue.add() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

dataqueue.add()

+

This function adds an entry to the data queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

result = dataqueue.add(value)

+

result = dataqueue.add(value, timeout)

+

+ + + + + + + + + + + + + + +

result

+

The resulting value of true or false based on the success of the function

+

value

+

The data item to add; value can be of any type

+

timeout

+

The maximum number of seconds to wait for space in the data queue

+
+

Details

+

You cannot use the timeout value when accessing the data queue from a remote node (you can only use the timeout value while adding data to the local data queue).

+

The timeout value is ignored if the data queue is not full.

+

The dataqueue.add() function returns false:

+
  • If the timeout expires before space is available in the data queue
  • If the data queue is full and a timeout value is not specified

If the value is a table, a duplicate of the table and any subtables is made. The duplicate table does not contain any references to the original table or to any subtables.

+

Example

+

+ + + + + + +

dataqueue.clear()

+

dataqueue.add(10)

+

dataqueue.add(11, 2)

+

result = dataqueue.add(12, 3)

+

if result == false then

+

print("Failed to add 12 to the dataqueue")

+

end

+

print("The dataqueue contains:")

+

while dataqueue.count > 0 do

+

print(dataqueue.next())

+

end

+

Clear the data queue.

+

Each line adds one item to the data queue.

+

Output:

+

The dataqueue contains:

+

10

+

11

+

12

+
+

Also see

+

dataqueue.CAPACITY

+

dataqueue.clear()

+

dataqueue.count

+

dataqueue.next()

+

Using the data queue for real-time communication

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14655.htm b/WebHelpDocs/2601B-PULSE/14655.htm new file mode 100644 index 0000000..48d1695 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14655.htm @@ -0,0 +1,96 @@ + + + + + dataqueue.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

dataqueue.clear()

+

This function clears the data queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

dataqueue.clear()

+

Details

+

This function forces all dataqueue.add() commands that are in progress to time out and deletes all data from the data queue.

+

Example

+

+ + + + + + +

MaxCount = dataqueue.CAPACITY

+

while dataqueue.count < MaxCount do

+

dataqueue.add(1)

+

end

+

print("There are " .. dataqueue.count

+

.. " items in the data queue")

+

dataqueue.clear()

+

print("There are " .. dataqueue.count

+

.. " items in the data queue")

+

This example fills the data queue and prints the number of items in the queue. It then clears the queue and prints the number of items again.

+

Output:

+

There are 128 items in the data
queue

+

There are 0 items in the data queue

+
+

Also see

+

dataqueue.add()

+

dataqueue.CAPACITY

+

dataqueue.count

+

dataqueue.next()

+

Using the data queue for real-time communication

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14656.htm b/WebHelpDocs/2601B-PULSE/14656.htm new file mode 100644 index 0000000..e287c90 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14656.htm @@ -0,0 +1,102 @@ + + + + + dataqueue.CAPACITY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

dataqueue.CAPACITY

+

This constant is the maximum number of entries that you can store in the data queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

count = dataqueue.CAPACITY

+

+ + + + + + +

count

+

The variable that is assigned the value of dataqueue.CAPACITY

+
+

Details

+

This constant always returns the maximum number of entries that can be stored in the data queue.

+

Example

+

+ + + + + + +

MaxCount = dataqueue.CAPACITY

+

while dataqueue.count < MaxCount do

+

dataqueue.add(1)

+

end

+

print("There are " .. dataqueue.count

+

.. " items in the data queue")

+

This example fills the data queue until it is full and prints the number of items in the queue.

+

Output:

+

There are 128 items in the data queue

+
+

Also see

+

dataqueue.add()

+

dataqueue.clear()

+

dataqueue.count

+

dataqueue.next()

+

Using the data queue for real-time communication

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14657.htm b/WebHelpDocs/2601B-PULSE/14657.htm new file mode 100644 index 0000000..9c218f6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14657.htm @@ -0,0 +1,109 @@ + + + + + dataqueue.count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

dataqueue.count

+

This attribute contains the number of items in the data queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

count = dataqueue.count

+

+ + + + + + +

count

+

The number of items in the data queue

+
+

Details

+

The count is updated as entries are added with dataqueue.add() and read from the data queue with dataqueue.next(). It is also updated when the data queue is cleared with dataqueue.clear().

+

A maximum of dataqueue.CAPACITY items can be stored at any one time in the data queue.

+

Example

+

+ + + + + + + + +

MaxCount = dataqueue.CAPACITY

+

while dataqueue.count < MaxCount do

+

dataqueue.add(1)

+

end

+

print("There are " .. dataqueue.count

+

.. " items in the data queue")

+

dataqueue.clear()

+

print("There are " .. dataqueue.count

+

.. " items in the data queue")

+

This example fills the data queue and prints the number of items in the queue. It then clears the queue and prints the number of items again.

+

Output:

+

There are 128 items in the data queue

+

There are 0 items in the data queue

+
+

Also see

+

dataqueue.add()

+

dataqueue.CAPACITY

+

dataqueue.clear()

+

dataqueue.next()

+

Using the data queue for real-time communication

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14658.htm b/WebHelpDocs/2601B-PULSE/14658.htm new file mode 100644 index 0000000..2a7d96a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14658.htm @@ -0,0 +1,131 @@ + + + + + dataqueue.next() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

dataqueue.next()

+

This function removes the next entry from the data queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

value = dataqueue.next()

+

value = dataqueue.next(timeout)

+

+ + + + + + + + + + +

value

+

The next entry in the data queue

+

timeout

+

The number of seconds to wait for data in the queue

+
+

Details

+

If the data queue is empty, the function waits up to the timeout value.

+

If data is not available in the data queue before the timeout expires, the return value is nil.

+

The entries in the data queue are removed in first-in, first-out (FIFO) order.

+

If the value is a table, a duplicate of the original table and any subtables is made. The duplicate table does not contain any references to the original table or to any subtables.

+

Example

+

+ + + + + + +

dataqueue.clear()

+

for i = 1, 10 do

+

dataqueue.add(i)

+

end

+

print("There are " .. dataqueue.count

+

.. " items in the data queue")

+

 

+

while dataqueue.count > 0 do

+

x = dataqueue.next()

+

print(x)

+

end

+

print("There are " .. dataqueue.count

+

.. " items in the data queue")

+

Clears the data queue, adds ten entries, then reads the entries from the data queue. Note that your output may differ depending on the setting of format.asciiprecision.

+

Output:

+

There are 10 items in the data queue

+

1

+

2

+

3

+

4

+

5

+

6

+

7

+

8

+

9

+

10

+

There are 0 items in the data queue

+
+

Also see

+

dataqueue.add()

+

dataqueue.CAPACITY

+

dataqueue.clear()

+

dataqueue.count

+

format.asciiprecision

+

Using the data queue for real-time communication

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14668.htm b/WebHelpDocs/2601B-PULSE/14668.htm new file mode 100644 index 0000000..700072f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14668.htm @@ -0,0 +1,102 @@ + + + + + digio.readbit() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.readbit()

+

This function reads one digital I/O line.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

data = digio.readbit(N)

+

+ + + + + + + + + + +

data

+

The state of the I/O line

+

N

+

Digital I/O line number to be read (1 to 14)

+
+

Details

+

A returned value of zero (0) indicates that the line is low. A returned value of one (1) indicates that the line is high.

+

Example

+

+ + + + + + +

print(digio.readbit(4))

+

Assume line 4 is set high, and it is then read.

+

Output:

+

1.00000e+00

+
+

Also see

+

digio.readport()

+

digio.writebit()

+

digio.writeport()

+

Digital I/O port

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14669.htm b/WebHelpDocs/2601B-PULSE/14669.htm new file mode 100644 index 0000000..b5817ce --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14669.htm @@ -0,0 +1,100 @@ + + + + + digio.readport() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.readport()

+

This function reads the digital I/O port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

data = digio.readport()

+

+ + + + + + +

data

+

The present value of the input lines on the digital I/O port

+
+

Details

+

The binary equivalent of the returned value indicates the value of the input lines on the I/O port. The least significant bit (bit B1) of the binary number corresponds to line 1; bit B14 corresponds to line 14.

+

For example, a returned value of 170 has a binary equivalent of 000000010101010, which indicates that lines 2, 4, 6, and 8 are high (1), and the other 10 lines are low (0).

+

Example

+

+ + + + + + +

data = digio.readport()

+

print(data)

+

Assume lines 2, 4, 6, and 8 are set high when the I/O port is read.

+

Output:

+

1.70000e+02

+

 

+

This is binary 10101010

+
+

Also see

+

digio.readbit()

+

digio.writebit()

+

digio.writeport()

+

Digital I/O port

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14670.htm b/WebHelpDocs/2601B-PULSE/14670.htm new file mode 100644 index 0000000..2385538 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14670.htm @@ -0,0 +1,91 @@ + + + + + digio.trigger[N].assert() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].assert()

+

This function asserts a trigger pulse on one of the digital I/O lines.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

digio.trigger[N].assert()

+

+ + + + + + +

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

The pulse width that is set determines how long the instrument asserts the trigger.

+

Example

+

+ + + + + + +

digio.trigger[2].assert()

+

Asserts a trigger on digital I/O line 2.

+
+

Also see

+

digio.trigger[N].pulsewidth

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14671.htm b/WebHelpDocs/2601B-PULSE/14671.htm new file mode 100644 index 0000000..9931146 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14671.htm @@ -0,0 +1,93 @@ + + + + + digio.trigger[N].clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].clear()

+

This function clears the trigger event on a digital I/O line.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

digio.trigger[N].clear()

+

+ + + + + + +

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

The event detector of a trigger enters the detected state when an event is detected. It is cleared when digio.trigger[N].wait() or digio.trigger[N].clear() is called.

+

digio.trigger[N].clear() clears the event detector of the specified trigger line, discards the history of the trigger line, and clears the digio.trigger[N].overrun attribute.

+

Example

+

+ + + + + + +

digio.trigger[2].clear()

+

Clears the trigger event detector on I/O line 2.

+
+

Also see

+

digio.trigger[N].overrun

+

digio.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14672.htm b/WebHelpDocs/2601B-PULSE/14672.htm new file mode 100644 index 0000000..d3b9983 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14672.htm @@ -0,0 +1,99 @@ + + + + + digio.trigger[N].EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].EVENT_ID

+

This constant identifies the trigger event generated by the digital I/O line N.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = digio.trigger[N].EVENT_ID

+

+ + + + + + + + + + +

eventID

+

The trigger event number

+

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

To have another trigger object respond to trigger events generated by the trigger line, set the stimulus attribute of the other object to the value of this constant.

+

Example

+

+ + + + + + + + +

digio.trigger[5].stimulus = digio.trigger[3].EVENT_ID

+

Uses a trigger event on digital I/O trigger line 3 to be the stimulus for digital I/O trigger line 5.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14674.htm b/WebHelpDocs/2601B-PULSE/14674.htm new file mode 100644 index 0000000..a06a6cd --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14674.htm @@ -0,0 +1,172 @@ + + + + + digio.trigger[N].mode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].mode

+

This attribute sets the mode in which the trigger event detector and the output trigger generator operate on the given trigger line.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Digital I/O trigger N reset
Recall setup

+

Not saved

+

0 (digio.TRIG_BYPASS)

+
+

Usage

+

triggerMode = digio.trigger[N].mode

+

digio.trigger[N].mode = triggerMode

+

+ + + + + + + + + + +

triggerMode

+

The trigger mode; see Details for values

+

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

Set triggerMode to one of the following values:

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger mode values

+

triggerMode

+

Description

+

digio.TRIG_BYPASS or 0

+

Allows direct control of the line.

+

digio.TRIG_FALLING or 1

+

Detects falling-edge triggers as input; asserts a TTL-low pulse for output.

+

digio.TRIG_RISING or 2

+

If the programmed state of the line is high, the digio.TRIG_RISING mode behavior is similar to digio.TRIG_RISINGA. If the programmed state of the line is low, the digio.TRIG_RISING mode behavior is similar to digio.TRIG_RISINGM. This setting should only be used if necessary for compatibility with other Keithley Instruments products.

+

digio.TRIG_EITHER or 3

+

Detects rising- or falling-edge triggers as input. Asserts a TTL-low pulse for output.

+

digio.TRIG_SYNCHRONOUSA or 4

+

Detects the falling-edge input triggers and automatically latches and drives the trigger line low. Asserting the output trigger releases the latched line.

+

digio.TRIG_SYNCHRONOUS or 5

+

Detects the falling-edge input triggers and automatically latches and drives the trigger line low. Asserts a TTL-low pulse as an output trigger.

+

digio.TRIG_SYNCHRONOUSM or 6

+

Detects rising-edge triggers as input. Asserts a TTL-low pulse for output.

+

digio.TRIG_RISINGA or 7

+

Detects rising-edge triggers as input. Asserts a TTL-low pulse for output.

+

digio.TRIG_RISINGM or 8

+

Asserts a TTL-high pulse for output. Input edge detection is not possible in this mode.

+
+

When programmed to any mode except digio.TRIG_BYPASS, the output state of the I/O line is controlled by the trigger logic, and the user-specified output state of the line is ignored.

+

Use of either digio.TRIG_SYNCHRONOUSA or digio.TRIG_SYNCHRONOUSM is preferred over digio.TRIG_SYNCHRONOUS, because digio.TRIG_SYNCHRONOUS is provided for compatibility with the digital I/O and TSP-Link triggering on older firmware.

+

To control the line state, set the mode to digio.TRIG_BYPASS and use the digio.writebit() and digio.writeport() commands.

+

Example

+

+ + + + + + +

digio.trigger[4].mode = 2

+

Sets the trigger mode for I/O line 4 to digio.TRIG_RISING.

+
+

Also see

+

digio.trigger[N].clear()

+

digio.trigger[N].reset()

+

digio.writebit()

+

digio.writeport()

+

Sweep operation

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14675.htm b/WebHelpDocs/2601B-PULSE/14675.htm new file mode 100644 index 0000000..665bbee --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14675.htm @@ -0,0 +1,101 @@ + + + + + digio.trigger[N].overrun + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].overrun

+

This attribute returns the event detector overrun status.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Instrument reset
Digital I/O trigger N clear
Digital I/O trigger N reset
Recall setup

+

Not saved

+

Not applicable

+
+

Usage

+

overrun = digio.trigger[N].overrun

+

+ + + + + + + + + + +

overrun

+

Trigger overrun state (true or false)

+

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

If this is true, an event was ignored because the event detector was already in the detected state when the event occurred.

+

This is an indication of the state of the event detector built into the line itself. It does not indicate if an overrun occurred in any other part of the trigger model or in any other detector that is monitoring the event.

+

Example

+

+ + + + + + +

overrun = digio.trigger[1].overrun

+

print(overrun)

+

If there is no trigger overrun, the following text is output:

+

false

+
+

Also see

+

digio.trigger[N].clear()

+

digio.trigger[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14677.htm b/WebHelpDocs/2601B-PULSE/14677.htm new file mode 100644 index 0000000..2c94908 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14677.htm @@ -0,0 +1,92 @@ + + + + + digio.trigger[N].release() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].release()

+

This function releases an indefinite length or latched trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

digio.trigger[N].release()

+

+ + + + + + +

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

Releases a trigger that was asserted with an indefinite pulsewidth time. It also releases a trigger that was latched in response to receiving a synchronous mode trigger. Only the specified trigger line is affected.

+

Example

+

+ + + + + + +

digio.trigger[4].release()

+

Releases digital I/O trigger line 4.

+
+

Also see

+

digio.trigger[N].assert()

+

digio.trigger[N].pulsewidth

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14679.htm b/WebHelpDocs/2601B-PULSE/14679.htm new file mode 100644 index 0000000..27024eb --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14679.htm @@ -0,0 +1,108 @@ + + + + + digio.trigger[N].wait() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].wait()

+

This function waits for a trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

triggered = digio.trigger[N].wait(timeout)

+

+ + + + + + + + + + + + + + +

triggered

+

The value true if a trigger is detected, or false if no triggers are detected during the timeout period

+

N

+

Digital I/O trigger line (1 to 14)

+

timeout

+

Timeout in seconds

+
+

Details

+

This function pauses for up to timeout seconds for an input trigger. If one or more trigger events are detected since the last time digio.trigger[N].wait() or digio.trigger[N].clear() was called, this function returns a value immediately. After waiting for a trigger with this function, the event detector is automatically reset and ready to detect the next trigger. This is true regardless of the number of events detected.

+

Example

+

+ + + + + + +

triggered = digio.trigger[4].wait(3)

+

print(triggered)

+

Waits up to three seconds for a trigger to be detected on trigger line 4, then outputs the results.

+

Output if no trigger is detected:

+

false

+

Output if a trigger is detected:

+

true

+
+

Also see

+

digio.trigger[N].clear()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14680.htm b/WebHelpDocs/2601B-PULSE/14680.htm new file mode 100644 index 0000000..5e195b8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14680.htm @@ -0,0 +1,104 @@ + + + + + digio.writebit() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.writebit()

+

This function sets a digital I/O line high or low.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

digio.writebit(N, data)

+

+ + + + + + + + + + +

N

+

Digital I/O trigger line (1 to 14)

+

data

+

The value to write to the bit:

+
  • 0 (low)
  • Non-zero (high)
+

Details

+

If the output line is write-protected using the digio.writeprotect attribute, the command is ignored.

+

The reset() function does not affect the present state of the digital I/O lines.

+

Use the digio.writebit() and digio.writeport() commands to control the output state of the synchronization line when trigger operation is set to digio.TRIG_BYPASS.

+

The data must be zero (0) to clear the bit. Any value other than zero (0) sets the bit.

+

Example

+

+ + + + + + +

digio.writebit(4, 0)

+

Sets digital I/O line 4 low (0).

+
+

Also see

+

digio.readbit()

+

digio.readport()

+

digio.trigger[N].mode

+

digio.writeport()

+

digio.writeprotect

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14681.htm b/WebHelpDocs/2601B-PULSE/14681.htm new file mode 100644 index 0000000..052cc9c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14681.htm @@ -0,0 +1,97 @@ + + + + + digio.writeport() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.writeport()

+

This function writes to all digital I/O lines.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

digio.writeport(data)

+

+ + + + + + +

data

+

Value to write to the port (0 to 16383)

+
+

Details

+

The binary representation of data indicates the output pattern to be written to the I/O port. For example, a data value of 170 has a binary equivalent of 00000010101010. Lines 2, 4, 6, and 8 are set high (1), and the other 10 lines are set low (0).

+

Write-protected lines are not changed.

+

The reset() function does not affect the present states of the digital I/O lines.

+

Use the digio.writebit() and digio.writeport() commands to control the output state of the synchronization line when trigger operation is set to digio.TRIG_BYPASS.

+

Example

+

+ + + + + + +

digio.writeport(255)

+

Sets digital I/O Lines 1 through 8 high (binary 00000011111111).

+
+

Also see

+

digio.readbit()

+

digio.readport()

+

digio.writebit()

+

digio.writeprotect

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14682.htm b/WebHelpDocs/2601B-PULSE/14682.htm new file mode 100644 index 0000000..2f70b45 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14682.htm @@ -0,0 +1,95 @@ + + + + + digio.writeprotect + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.writeprotect

+

This attribute contains the write-protect mask that protects bits from changes from the digio.writebit() and digio.writeport() functions.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Saved setup

+

0

+
+

+

Usage

+

mask = digio.writeprotect

+

digio.writeprotect = mask

+

+ + + + + + +

mask

+

Sets the value that specifies the bit pattern for write-protect

+
+

Details

+

Bits that are set to one cause the corresponding line to be write-protected.

+

The binary equivalent of mask indicates the mask to be set for the I/O port. For example, a mask value of 7 has a binary equivalent of 00000000000111. This mask write-protects lines 1, 2, and 3.

+

Example

+

+ + + + + + +

digio.writeprotect = 15

+

Write-protects lines 1, 2, 3, and 4.

+
+

Also see

+

digio.writebit()

+

digio.writeport()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14699.htm b/WebHelpDocs/2601B-PULSE/14699.htm new file mode 100644 index 0000000..05de7db --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14699.htm @@ -0,0 +1,72 @@ + + + + + display.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.clear()

+

This function clears all lines of the front-panel display.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.clear()

+

Details

+

This function switches to the user screen and then clears the front-panel display.

+

The display.clear(), display.setcursor(), and display.settext() functions are overlapped commands. That is, the script does not wait for one of these commands to complete. These functions do not immediately update the display. For performance considerations, they update the display as soon as processing time becomes available.

+

Also see

+

display.setcursor()

+

display.settext()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14700.htm b/WebHelpDocs/2601B-PULSE/14700.htm new file mode 100644 index 0000000..68b722c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14700.htm @@ -0,0 +1,121 @@ + + + + + display.getcursor() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.getcursor()

+

This function reads the present position of the cursor on the front-panel display.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

row, column, style = display.getcursor()

+

+ + + + + + + + + + + + + + +

row

+

The row where the cursor is: 1 (top row); 2 (bottom row)

+

column

+

The column where the cursor is:

+
  • If the cursor is in the top row: 1 to 20
  • If the cursor is in the bottom row: 1 to 32

style

+

Visibility of the cursor:

+
  • Invisible: 0
  • Blinking: 1
+

Details

+

This function switches the front-panel display to the user screen (the text set by display.settext()), and then returns values to indicate the cursor's row and column position and cursor style.

+

Columns are numbered from left to right on the display.

+

Example 1

+

+ + + + + + +

testRow, testColumn = display.getcursor()

+

print(testRow, testColumn)

+

This example reads the cursor position into local variables and prints them. Example output:

+

1.00000e+00 1.00000e+00

+
+

Example 2

+

+ + + + + + +

print(display.getcursor())

+

This example prints the cursor position directly. In this example, the cursor is in row 1 at column 3, with an invisible cursor:

+

1.00000e+00 3.00000e+00 0.00000e+00

+
+

Also see

+

display.gettext()

+

display.screen

+

display.setcursor()

+

display.settext()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14702.htm b/WebHelpDocs/2601B-PULSE/14702.htm new file mode 100644 index 0000000..2e6c6fc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14702.htm @@ -0,0 +1,160 @@ + + + + + display.gettext() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.gettext()

+

This function reads the text displayed on the front panel.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

text = display.gettext()

+

text = display.gettext(embellished)

+

text = display.gettext(embellished, row)

+

text = display.gettext(embellished, row, columnStart)

+

text = display.gettext(embellished, row, columnStart, columnEnd)

+

+ + + + + + + + + + + + + + + + + + + + + + +

text

+

The returned value, which contains the text that is presently displayed

+

embellished

+

Indicates type of returned text: false (simple text); true (text with embedded character codes)

+

row

+

Selects the row from which to read the text: 1 (row 1); 2 (row 2). If row is not included, both rows of text are read

+

columnStart

+

Selects the first column from which to read text; for row 1, the valid column numbers are 1 to 20; for row 2, the valid column numbers are 1 to 32; if nothing is selected, 1 is used

+

columnEnd

+

Selects the last column from which to read text; for row 1, the valid column numbers are 1 to 20; for row 2, the valid column numbers are 1 to 32; the default is 20 for row 1, and 32 for row 2

+
+

Details

+

Using the command without any parameters returns both lines of the front-panel display.

+

The $N character code is included in the returned value to show where the top line ends and the bottom line begins. This is not affected by the value of embellished.

+

When embellished is set to true, all other character codes are returned along with the message. When embellished is set to false, only the message and the $N character code is returned. For information on the embedded character codes, see display.settext().

+

The display is not switched to the user screen (the screen set using display.settext()). Text is read from the active screen.

+

Example 1

+

+ + + + + + + + +

display.clear()

+

display.setcursor(1, 1)

+

display.settext("ABCDEFGHIJ$DKLMNOPQRST")

+

display.setcursor(2, 1)

+

display.settext("abcdefghijklm$Bnopqrstuvwxyz$F123456")

+

print(display.gettext())

+

print(display.gettext(true))

+

print(display.gettext(false, 2))

+

print(display.gettext(true, 2, 9))

+

print(display.gettext(false, 2, 9, 10))

+

This example shows how to retrieve the display text in multiple ways. The output is:

+

 

+

ABCDEFGHIJKLMNOPQRST$Nabcdefghijklmnopqrstuvwxyz123456

+

$RABCDEFGHIJ$DKLMNOPQRST$N$Rabcdefghijklm$Bnopqrstuvwxyz$F123456

+

abcdefghijklmnopqrstuvwxyz123456

+

$Rijklm$Bnopqrstuvwxyz$F123456

+

ij

+
+

Example 2

+

+ + + + + + + + +

display.clear()

+

display.settext("User Screen")

+

text = display.gettext()

+

print(text)

+

This outputs all text in both lines of the display:

+

User Screen $N

+

This indicates that the message “User Screen” is on the top line. The bottom line is blank.

+
+

Also see

+

display.clear()

+

display.getcursor()

+

display.setcursor()

+

display.settext()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14703.htm b/WebHelpDocs/2601B-PULSE/14703.htm new file mode 100644 index 0000000..b778d11 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14703.htm @@ -0,0 +1,172 @@ + + + + + display.inputvalue() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.inputvalue()

+

This function displays a formatted input field on the front-panel display that the operator can edit.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.inputvalue("format")

+

display.inputvalue("format", default)

+

display.inputvalue("format", default, minimum)

+

display.inputvalue("format", default, minimum, maximum)

+

+ + + + + + + + + + + + + + + + + + +

format

+

A string that defines how the input field is formatted; see Details for more information

+

default

+

The default value for the input value

+

minimum

+

The minimum input value

+

maximum

+

The maximum input value

+
+

Details

+

The format parameter uses zeros (0), the decimal point, polarity sign, and exponents to define how the input field is formatted. The format parameter can include the options shown in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + +

Option

+

Description

+

Examples

+

E

+

Include the E to display the value exponentially

+

0.00000e+0

+

+

+

Allows operators to enter positive or negative values; if the "+" sign is not included, the operator cannot enter a negative value

+

+0.00

+

0

+

Defines the digit positions for the value; you can use up to six zeros (0)

+

+00.0000e+00

+

.

+

Include to have a decimal point appear in the value

+

+0.00

+
+

The default parameter is the value shown when the value is first displayed.

+

The minimum and maximum parameters can be used to limit the values that can be entered. When + is not selected for format, the minimum limit must be more than or equal to zero (0). When limits are used, you cannot enter values above or below these limits.

+

The input value is limited to ±1e37.

+

Before calling display.inputvalue(), you should send a message prompt to the operator using display.prompt(). Make sure to position the cursor where the edit field should appear.

+

After this command is sent, script execution pauses until you enter a value and press the ENTER key.

+

For positive and negative entry (plus sign (+) used for the value field and/or the exponent field), polarity of a nonzero value or exponent can be toggled by positioning the cursor on the polarity sign and turning the navigation wheel navigation wheel. Polarity will also toggle when using the navigation wheel navigation wheel to decrease or increase the value or exponent past zero. A zero (0) value or exponent (for example, +00) is always positive and cannot be toggled to negative polarity.

+

After executing this command and pressing the EXIT (LOCAL) key, the function returns nil.

+

Example

+

+ + + + + + + + +

display.clear()

+

display.settext("Enter value between$N -0.10 and 2.00: ")

+

value = display.inputvalue("+0.00", 0.5, -0.1, 2.0)

+

print("Value entered = ", value)

+

Displays an editable field (+0.50) for operator input. The valid input range is -0.10 to +2.00, with a default of 0.50.

+

Output:

+

Value entered = 1.35000e+00

+
+

Also see

+

display.prompt()

+

display.setcursor()

+

display.settext()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14705.htm b/WebHelpDocs/2601B-PULSE/14705.htm new file mode 100644 index 0000000..b0e0919 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14705.htm @@ -0,0 +1,111 @@ + + + + + display.loadmenu.catalog() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.loadmenu.catalog()

+

This function creates an iterator for the user menu items accessed using the LOAD key on the front panel.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

for displayName in display.loadmenu.catalog() do body end

+

for displayName, code in display.loadmenu.catalog() do body end

+

+ + + + + + + + + + + + + + +

displayName

+

The name displayed in the menu

+

code

+

The code associated with the displayName

+

body

+

The body of the code to process the entries in the loop

+
+

Details

+

Each time through the loop, displayName and code will take on the values in the USER menu.

+

The instrument goes through the list in random order.

+

Example

+

+ + + + + + +

for displayName, code in display.loadmenu.catalog() do

+

print(displayName, code)

+

end

+

Output:

+

Test DUT1() beeper.beep(2, 500)

+

Part1 testpart([[Part1]], 5.0)

+

Test9 Test9()

+
+

Also see

+

display.loadmenu.add()

+

display.loadmenu.delete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14706.htm b/WebHelpDocs/2601B-PULSE/14706.htm new file mode 100644 index 0000000..f9a6437 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14706.htm @@ -0,0 +1,98 @@ + + + + + display.loadmenu.delete() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.loadmenu.delete()

+

This function removes an entry from the USER menu, which can be accessed using the LOAD key on the front panel.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.loadmenu.delete("displayName")

+

+ + + + + + +

displayName

+

The name to be deleted from the USER menu

+
+

Details

+

If you delete an entry from the USER menu, you can no longer run it by pressing the LOAD key.

+

Example

+

+ + + + + + +

display.loadmenu.delete("Test9")

+

for displayName, code in display.loadmenu.catalog() do

+

print(displayName, code)

+

end

+

Deletes the entry named Test9.

+

Output:

+

Test DUT1() beeper.beep(2, 500)

+

Part1 testpart([[Part1]], 5.0)

+
+

Also see

+

display.loadmenu.add()

+

display.loadmenu.catalog()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14707.htm b/WebHelpDocs/2601B-PULSE/14707.htm new file mode 100644 index 0000000..cfa9fba --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14707.htm @@ -0,0 +1,94 @@ + + + + + display.locallockout + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.locallockout

+

This attribute describes whether or not the EXIT (LOCAL) key on the instrument front panel is enabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Power cycle

+

Not saved

+

0 (display.UNLOCK)

+
+

Usage

+

lockout = display.locallockout

+

display.locallockout = lockout

+

+ + + + + + +

lockout

+

0 or display.UNLOCK: Unlocks EXIT (LOCAL) key

+

1 or display.LOCK: Locks out EXIT (LOCAL) key

+
+

Details

+

Set display.locallockout to display.LOCK to prevent the user from interrupting remote operation by pressing the EXIT (LOCAL) key.

+

Set this attribute to display.UNLOCK to allow the EXIT (LOCAL) key to interrupt script or remote operation.

+

Example

+

+ + + + + + +

display.locallockout = display.LOCK

+

Disables the front-panel EXIT (LOCAL) key.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14708.htm b/WebHelpDocs/2601B-PULSE/14708.htm new file mode 100644 index 0000000..34187ca --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14708.htm @@ -0,0 +1,110 @@ + + + + + display.menu() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.menu()

+

This function presents a menu on the front-panel display.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

selection = display.menu("name", "items")

+

+ + + + + + + + + + + + + + +

selection

+

Name of the variable that holds the selected menu item

+

name

+

Menu name to display on the top line

+

items

+

Menu items to display on the bottom line

+
+

Details

+

The menu consists of the menu name string on the top line, and a selectable list of items on the bottom line. The menu items must be a single string with each item separated by whitespace. The name for the top line is limited to 20 characters.

+

After sending this command, script execution pauses for the operator to select a menu item. An item is selected by rotating the navigation wheel navigation wheel to place the blinking cursor on the item, and then pressing the navigation wheel navigation wheel (or the ENTER key). When an item is selected, the text of that selection is returned.

+

Pressing the EXIT (LOCAL) key will not abort the script while the menu is displayed, but it will return nil. The script can be aborted by calling the exit function when nil is returned.

+

Example

+

+ + + + + + + + +

selection = display.menu("Menu", "Test1 Test2 Test3")

+

print(selection)

+

Displays a menu with three menu items. If the second menu item is selected, selection is given the value Test2.

+

Output:

+

Test2

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14709.htm b/WebHelpDocs/2601B-PULSE/14709.htm new file mode 100644 index 0000000..08d605e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14709.htm @@ -0,0 +1,93 @@ + + + + + display.numpad + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.numpad

+

This attribute controls whether the front panel keys act as a numeric keypad during value entry.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Saved setup

+

1 (display.ENABLE)

+
+

Usage

+

numericKeypad = display.numpad

+

display.numpad = numericKeypad

+

+ + + + + + +

numericKeypad

+

Enable the numeric keypad feature (1 or display.ENABLE)

+

Disable the numeric keypad feature (0 or display.DISABLE)

+
+

Details

+

The numeric keypad feature is only available when editing a numeric value at the same time that the EDIT indicator is lit.

+

Example

+

+ + + + + + +

display.numpad = display.ENABLE

+

Turn on the numeric keypad feature.

+
+

Also see

+

Setting a value

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14711.htm b/WebHelpDocs/2601B-PULSE/14711.htm new file mode 100644 index 0000000..ac7b7fb --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14711.htm @@ -0,0 +1,117 @@ + + + + + display.setcursor() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.setcursor()

+

This function sets the position of the cursor.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.setcursor(row, column)

+

display.setcursor(row, column, style)

+

+ + + + + + + + + + + + + + +

row

+

The row number for the cursor (1 or 2)

+

column

+

The active column position to set; row 1 has columns 1 to 20, row 2 has columns 1 to 32

+

style

+

Set the cursor to invisible (0, default) or blinking (1)

+
+

Details

+

Sending this command selects the user screen and then moves the cursor to the given location.

+

The display.clear(), display.setcursor(), and display.settext() functions are overlapped commands. That is, the script does not wait for one of these commands to complete. These functions do not immediately update the display. For performance considerations, they update the display as soon as processing time becomes available.

+

An out-of-range parameter for row sets the cursor to row 2. An out-of-range parameter for column sets the cursor to column 20 for row 1, or 32 for row 2.

+

An out-of-range parameter for style sets it to 0 (invisible).

+

A blinking cursor is only visible when it is positioned over displayed text. It cannot be seen when positioned over a space character.

+

Example

+

+ + + + + + +

display.clear()

+

display.setcursor(1, 8)

+

display.settext("Hello")

+

display.setcursor(2, 14)

+

display.settext("World")

+

This example displays a message on the front panel, approximately center. Note that the top line of text is larger than the bottom line of text.

+

The front panel of the instrument displays "Hello" on the top line and "World" on the second line.

+
+

Also see

+

display.clear()

+

display.getcursor()

+

display.gettext()

+

display.screen

+

display.settext()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14712.htm b/WebHelpDocs/2601B-PULSE/14712.htm new file mode 100644 index 0000000..552a2fe --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14712.htm @@ -0,0 +1,157 @@ + + + + + display.settext() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.settext()

+

This function displays text on the front-panel user screen.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.settext("text")

+

+ + + + + + +

text

+

Text message to be displayed, with optional character codes

+
+

Details

+

This function selects the user display screen and displays the given text.

+

After the instrument is turned on, the first time you use a display command to write to the display, the message "User Screen" is cleared. After the first write, you need to use display.clear() to clear the message.

+

The display.clear(), display.setcursor(), and display.settext() functions are overlapped commands. That is, the script does not wait for one of these commands to complete. These functions do not immediately update the display. For performance considerations, they update the display as soon as processing time becomes available.

+

The text starts at the present cursor position. After the text is displayed, the cursor is after the last character in the display message.

+

Top line text does not wrap to the bottom line of the display automatically. Any text that does not fit on the current line is truncated. If the text is truncated, the cursor remains at the end of the line.

+

The text remains on the display until replaced or cleared.

+

The character codes described in the following table can be also be included in the text string.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Display character codes

+

Character Code

+

Description

+

$N

+

Newline, starts text on the next line; if the cursor is already on line 2, text will be ignored after the $N is received

+

$R

+

Sets text to normal intensity, nonblinking

+

$B

+

Sets text to blink

+

$D

+

Sets text to dim intensity

+

$F

+

Sets the text to background blink

+

$$

+

Escape sequence to display a single dollar symbol ($)

+
+

Example

+

+ + + + + + + + +

display.clear()

+

display.settext("Normal $BBlinking$N")

+

display.settext("$DDim $FBackgroundBlink$R $$$$ 2 dollars")

+

This example sets the display to:

+

Normal Blinking

+

Dim BackgroundBlink $$ 2 dollars

+

with the named effect on each word.

+
+

Also see

+

display.clear()

+

display.getcursor()

+

display.gettext()

+

display.screen

+

display.setcursor()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14715.htm b/WebHelpDocs/2601B-PULSE/14715.htm new file mode 100644 index 0000000..2e2593f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14715.htm @@ -0,0 +1,72 @@ + + + + + display.trigger.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.trigger.clear()

+

This function clears the front-panel trigger event detector.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.trigger.clear()

+

Details

+

The trigger event detector remembers if an event has been detected since the last display.trigger.wait() call. This function clears the trigger event detector and discards the previous history of TRIG key presses.

+

This attribute also clears the display.trigger.overrun attribute.

+

Also see

+

display.trigger.overrun

+

display.trigger.wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14716.htm b/WebHelpDocs/2601B-PULSE/14716.htm new file mode 100644 index 0000000..dbe8919 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14716.htm @@ -0,0 +1,80 @@ + + + + + display.trigger.EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.trigger.EVENT_ID

+

This constant is the event ID of the event generated when the front-panel TRIG key is pressed.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = display.trigger.EVENT_ID

+

+ + + + + + +

eventID

+

The trigger event number

+
+

Details

+

Set the stimulus of any trigger event detector to the value of this constant to have it respond to front-panel trigger key events.

+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14717.htm b/WebHelpDocs/2601B-PULSE/14717.htm new file mode 100644 index 0000000..b3a950f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14717.htm @@ -0,0 +1,101 @@ + + + + + display.trigger.wait() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.trigger.wait()

+

This function waits for the TRIG key on the front panel to be pressed.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

triggered = display.trigger.wait(timeout)

+

+ + + + + + + + + + +

triggered

+

true: Trigger was detected

+

false: The operation timed out

+

timeout

+

Timeout in seconds

+
+

Details

+

If the trigger key was previously pressed and one or more trigger events were detected, this function returns immediately.

+

After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.

+

Use the display.trigger.clear() call to clear the trigger event detector.

+

Example

+

+ + + + + + +

triggered = display.trigger.wait(5)

+

print(triggered)

+

Waits up to five seconds for the TRIG key to be pressed. If TRIG is pressed within five seconds, the output is true. If not, the output is false.

+
+

Also see

+

display.trigger.clear()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14719.htm b/WebHelpDocs/2601B-PULSE/14719.htm new file mode 100644 index 0000000..1ca8fae --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14719.htm @@ -0,0 +1,300 @@ + + + + + display.getannunciators() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.getannunciators()

+

This function reads the annunciators (indicators) that are presently turned on.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

annunciators = display.getannunciators()

+

+ + + + + + +

annunciators

+

The bitmasked value that shows which indicators are turned on

+
+

Details

+

This function returns a bitmasked value showing which indicators are turned on. The 16-bit binary equivalent of the returned value is the bitmask. The return value is a sum of set annunciators, based on the weighted value, as shown in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Annunciator (indicator) bitmasked values and equivalent constants

+

Indicator

+

Bit

+

Weighted value

+

Equivalent constant

+

FILT

+

1

+

1

+

display.ANNUNCIATOR_FILTER

+

MATH

+

2

+

2

+

display.ANNUNCIATOR_MATH

+

4W

+

3

+

4

+

display.ANNUNCIATOR_4_WIRE

+

AUTO

+

4

+

8

+

display.ANNUNCIATOR_AUTO

+

ARM

+

5

+

16

+

display.ANNUNCIATOR_ARM

+

TRIG

+

6

+

32

+

display.ANNUNCIATOR_TRIGGER

+

* (asterisk)

+

7

+

64

+

display.ANNUNCIATOR_STAR

+

SMPL

+

8

+

128

+

display.ANNUNCIATOR_SAMPLE

+

EDIT

+

9

+

256

+

display.ANNUNCIATOR_EDIT

+

ERR

+

10

+

512

+

display.ANNUNCIATOR_ERROR

+

REM

+

11

+

1024

+

display.ANNUNCIATOR_REMOTE

+

TALK

+

12

+

2048

+

display.ANNUNCIATOR_TALK

+

LSTN

+

13

+

4096

+

display.ANNUNCIATOR_LISTEN

+

SRQ

+

14

+

8192

+

display.ANNUNCIATOR_SRQ

+

REAR

+

15

+

16384

+

display.ANNUNCIATOR_REAR

+

REL

+

16

+

32768

+

display.ANNUNCIATOR_REL

+
+

Example 1

+

+ + + + + + +

testAnnunciators = display.getannunciators()

+

print(testAnnunciators)

+

 

+

rem = bit.bitand(testAnnunciators, 1024)

+

if rem > 0 then

+

print("REM is on")

+

else

+

print("REM is off")

+

end

+

REM indicator is turned on.

+

Output:

+

1.28000e+03

+

REM is on

+
+

Example 2

+

+ + + + + + +

print(display.ANNUNCIATOR_EDIT)

+

 

+

print(display.ANNUNCIATOR_TRIGGER)

+

 

+

print(display.ANNUNCIATOR_AUTO)

+

Output:

+

2.56000e+02

+

 

+

3.20000e+01

+

 

+

8.00000e+00

+
+

Also see

+

bit.bitand()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14739.htm b/WebHelpDocs/2601B-PULSE/14739.htm new file mode 100644 index 0000000..483b7b0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14739.htm @@ -0,0 +1,93 @@ + + + + + display.trigger.overrun + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.trigger.overrun

+

This attribute contains the event detector overrun status.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Display trigger clear
Instrument reset
Recall setup

+

Not saved

+

false

+
+

Usage

+

overrun = display.trigger.overrun

+

+ + + + + + +

overrun

+

The trigger overrun state (true or false)

+
+

Details

+

Indicates if a trigger event was ignored because the event detector was already in the detected state when the TRIG button was pressed.

+

Indicates the overrun state of the event detector built into the display.

+

This attribute does not indicate whether an overrun occurred in any other part of the trigger model or in any other detector that is monitoring the event.

+

Example

+

+ + + + + + +

overrun = display.trigger.overrun

+

Sets the variable overrun equal to the present state of the event detector built into the display.

+
+

Also see

+

display.trigger.clear()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14740.htm b/WebHelpDocs/2601B-PULSE/14740.htm new file mode 100644 index 0000000..de14d11 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14740.htm @@ -0,0 +1,185 @@ + + + + + display.prompt() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.prompt()

+

This function prompts the user to enter a parameter from the front panel of the instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.prompt("format", "units", "help")

+

display.prompt("format", "units", "help", default)

+

display.prompt("format", "units", "help", default, minimum)

+

display.prompt("format", "units", "help", default, minimum, maximum)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

format

+

A string that defines how the input field is formatted; see Details for more information

+

units

+

Set the units text string for the top line (eight characters maximum); this indicates the units (for example, "V" or "A") for the value

+

help

+

Text string to display on the bottom line (32 characters maximum)

+

default

+

The value that is shown when the value is first displayed

+

minimum

+

The minimum input value that can be entered

+

maximum

+

The maximum input value that can be entered (must be more than minimum)

+
+

Details

+

This function creates an editable input field at the present cursor position, and an input prompt message on the bottom line. Example of a displayed input field and prompt:

+

0.00V

+

Input 0 to +2V

+

The format parameter uses zeros (0), the decimal point, polarity sign, and exponents to define how the input field is formatted.

+

The format parameter can include the options shown in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + +

Option

+

Description

+

Examples

+

E

+

Include the E to display the value exponentially. Include a plus sign (+) for positive/negative exponent entry. Do not include the plus sign (+) to prevent negative value entry. 0 defines the digit positions for the exponent.

+

 

+

0.00000E+0

+

+

+

Allows operators to enter positive or negative values. If the plus sign (+) is not included, the operator cannot enter a negative value.

+

+0.00

+

0

+

Defines the digit positions for the value. You can use up to six zeros (0).

+

+00.0000E+00

+

.

+

The decimal point where needed for the value.

+

+0.00

+
+

You can use the minimum and maximum parameters to limit the values that can be entered. When a plus sign (+) is not selected for format, the minimum limit must be greater than or equal to zero (0). When limits are used, the operator cannot enter values above or below these limits.

+

The input value is limited to ±1e37.

+

After sending this command, script execution pauses for the operator to enter a value and press ENTER.

+

For positive and negative entry (plus sign (+) used for the value field and the exponent field), polarity of a nonzero value or exponent can be toggled by positioning the cursor on the polarity sign and turning the navigation wheel navigation wheel. Polarity will also toggle when using the navigation wheel navigation wheel to decrease or increase the value or exponent past zero. A zero value or exponent (for example, +00) is always positive and cannot be toggled to negative polarity.

+

After executing this command and pressing the EXIT (LOCAL) key, the value returns nil.

+

Example

+

+ + + + + + + + +

value = display.prompt("0.00", "V", "Input 0 to +2V", 0.5, 0, 2)

+

print(value)

+

The above command prompts the operator to enter a voltage value. The valid input range is 0 to +2.00, with a default of 0.50:

+

0.50V

+

Input 0 to +2V

+

If the operator enters 0.70, the output is:

+

7.00000e-01

+
+

Also see

+

display.inputvalue()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14748.htm b/WebHelpDocs/2601B-PULSE/14748.htm new file mode 100644 index 0000000..e7ac1f9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14748.htm @@ -0,0 +1,47 @@ + + + + + Error queue + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Error queue

+

When errors and events occur, the error and status messages are placed in the error queue. Use the error queue commands to request error and status message information.

+

errorqueue.clear()

+

errorqueue.count

+

errorqueue.next()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14749.htm b/WebHelpDocs/2601B-PULSE/14749.htm new file mode 100644 index 0000000..5988a5d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14749.htm @@ -0,0 +1,71 @@ + + + + + errorqueue.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

errorqueue.clear()

+

This function clears all entries out of the error queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

errorqueue.clear()

+

Details

+

See the Error queue topic for additional information about the error queue.

+

Also see

+

errorqueue.count

+

errorqueue.next()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14750.htm b/WebHelpDocs/2601B-PULSE/14750.htm new file mode 100644 index 0000000..68509a6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14750.htm @@ -0,0 +1,94 @@ + + + + + errorqueue.count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

errorqueue.count

+

This attribute gets the number of entries in the error queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Power cycle
Clearing error queue
Reading error messages

+

Not applicable

+

Not applicable

+
+

Usage

+

count = errorqueue.count

+

+ + + + + + +

count

+

The number of entries in the error queue

+
+

Example

+

+ + + + + + +

count = errorqueue.count

+

print(count)

+

Returns the number of entries in the error queue.

+

The output below indicates that there are four entries in the error queue:

+

4.00000e+00

+
+

Also see

+

Error queue

+

errorqueue.clear()

+

errorqueue.next()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14756.htm b/WebHelpDocs/2601B-PULSE/14756.htm new file mode 100644 index 0000000..864ca27 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14756.htm @@ -0,0 +1,102 @@ + + + + + eventlog.all() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

eventlog.all()

+

This function returns all entries from the event log as a single string and removes them from the event log.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

logString = eventlog.all()

+

+ + + + + + +

logString

+

A listing of all event log entries

+
+

Details

+

This function returns all events in the event log. Logged items are shown from oldest to newest. The response is a string that has the messages delimited with a new line character.

+

This function also clears the event log.

+

If there are no entries in the event log, this function returns the value nil.

+

Example

+

+ + + + + + + + +

print(eventlog.all())

+

Get and print all entries from the event log and remove the entries from the log.

+

Output:

+

17:26:35.690 10 Oct 2019, LAN0, 192.168.1.102, LXI, 0, 1570728395,
1192037155.733269000, 0, 0x0

+

17:26:39.009 10 Oct 2019, LAN5, 192.168.1.102, LXI, 0, 1570728399,
1192037159.052777000, 0, 0x0

+
+

Also see

+

eventlog.clear()

+

eventlog.count

+

eventlog.enable

+

eventlog.next()

+

eventlog.overwritemethod

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14757.htm b/WebHelpDocs/2601B-PULSE/14757.htm new file mode 100644 index 0000000..6a10b02 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14757.htm @@ -0,0 +1,95 @@ + + + + + eventlog.count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

eventlog.count

+

This attribute returns the number of unread events in the event log.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Instrument reset
Clearing event log
Reading event log

+

Not applicable

+

Not applicable

+
+

Usage

+

N = eventlog.count

+

+ + + + + + +

N

+

The number of events in the event log

+
+

Example

+

+ + + + + + +

print(eventlog.count)

+

Displays the present number of events in the instrument event log.

+

Output looks similar to:

+

3.00000e+00

+
+

Also see

+

eventlog.all()

+

eventlog.clear()

+

eventlog.enable

+

eventlog.next()

+

eventlog.overwritemethod

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14758.htm b/WebHelpDocs/2601B-PULSE/14758.htm new file mode 100644 index 0000000..32f1ace --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14758.htm @@ -0,0 +1,74 @@ + + + + + eventlog.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

eventlog.clear()

+

This function clears the event log.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventlog.clear()

+

Details

+

This command removes all messages from the event log.

+

Also see

+

eventlog.all()

+

eventlog.count

+

eventlog.enable

+

eventlog.next()

+

eventlog.overwritemethod

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14759.htm b/WebHelpDocs/2601B-PULSE/14759.htm new file mode 100644 index 0000000..337a847 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14759.htm @@ -0,0 +1,97 @@ + + + + + eventlog.overwritemethod + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

eventlog.overwritemethod

+

This attribute controls how the event log processes events if the event log is full.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Not saved

+

1 (eventlog.DISCARD_OLDEST)

+
+

Usage

+

method = eventlog.overwritemethod

+

eventlog.overwritemethod = method

+

+ + + + + + +

method

+

Set to one of the following values:

+
  • 0 or eventlog.DISCARD_NEWEST: New entries are not logged
  • 1 or eventlog.DISCARD_OLDEST: Old entries are deleted as new events are logged
+

Details

+

When this attribute is set to eventlog.DISCARD_NEWEST, new entries are not logged.

+

When this attribute is set to eventlog.DISCARD_OLDEST, the oldest entry is discarded when a new entry is added.

+

Example

+

+ + + + + + +

eventlog.overwritemethod = 0

+

When the log is full, the event log will ignore new entries.

+
+

Also see

+

eventlog.all()

+

eventlog.clear()

+

eventlog.count

+

eventlog.enable

+

eventlog.next()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14760.htm b/WebHelpDocs/2601B-PULSE/14760.htm new file mode 100644 index 0000000..a3e0183 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14760.htm @@ -0,0 +1,104 @@ + + + + + eventlog.enable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

eventlog.enable

+

This attribute enables or disables the event log.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Not saved

+

1 (eventlog.ENABLE)

+
+

Usage

+

status = eventlog.enable

+

eventlog.enable = status

+

+ + + + + + +

status

+

The enable status of the event log:

+

1 or eventlog.ENABLE: Event log enable

+

0 or eventlog.DISABLE: Event log disable

+
+

Details

+

When the event log is disabled (eventlog.DISABLE or 0), no new events are added to the event log. You can, however, read and remove existing events.

+

When the event log is enabled, new events are logged.

+

Example

+

+ + + + + + +

print(eventlog.enable)

+

eventlog.enable = eventlog.DISABLE

+

print(eventlog.enable)

+

Displays the present status of the 2601B-PULSE event log.

+

Output:

+

1.00000e+00

+

0.00000e+00

+
+

Also see

+

eventlog.all()

+

eventlog.clear()

+

eventlog.count

+

eventlog.next()

+

eventlog.overwritemethod

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14761.htm b/WebHelpDocs/2601B-PULSE/14761.htm new file mode 100644 index 0000000..162611e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14761.htm @@ -0,0 +1,114 @@ + + + + + eventlog.next() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

eventlog.next()

+

This function returns the oldest unread event message from the event log and removes it from the event log.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

logString = eventlog.next()

+

+ + + + + + +

logString

+

The next log entry

+
+

Details

+

Returns the next entry from the event log and removes it from the log.

+

If there are no entries in the event log, returns the value nil.

+

Example 1

+

+ + + + + + + + +

print(eventlog.next())

+

Get the oldest message in the event log and remove that entry from the log.

+

Output:

+

17:28:22.085 10 Oct 2019, LAN2, 192.168.1.102, LXI, 0, 1570728502, <no time>, 0, 0x0

+
+

Example 2

+

+ + + + + + + + +

print(eventlog.next())

+

If you send this command when there is nothing in the event log, you will get the following output:

+

nil

+
+

Also see

+

eventlog.all()

+

eventlog.clear()

+

eventlog.count

+

eventlog.enable

+

eventlog.overwritemethod

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14769.htm b/WebHelpDocs/2601B-PULSE/14769.htm new file mode 100644 index 0000000..1b3c004 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14769.htm @@ -0,0 +1,71 @@ + + + + + exit() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

exit()

+

This function stops a script that is presently running.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

exit()

+

Details

+

Terminates script execution when called from a script that is being executed.

+

This command does not wait for overlapped commands to complete before terminating script execution. If overlapped commands are required to finish, use the waitcomplete() function before calling exit().

+

Also see

+

waitcomplete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14771.htm b/WebHelpDocs/2601B-PULSE/14771.htm new file mode 100644 index 0000000..7dce09e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14771.htm @@ -0,0 +1,86 @@ + + + + + File I/O + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

File I/O

+

You can use the file I/O commands to open and close directories and files, write data, or to read a file on an installed USB flash drive. File I/O commands are organized into two groups:

+
  • Commands that reside in the fs and io table, for example: io.open(), io.close(), io.input(), and io.output(). Use these commands to manage file system directories; open and close file descriptors; and perform basic I/O operations on a pair of default files (one input and one output).
  • Commands that reside in the file descriptors (for example: fileVar:seek(), fileVar:write(), and fileVar:read()) operate exclusively on the file with which they are associated.

The root folder of the USB flash drive has the absolute path:

+

"/usb1/"

+

VARIABLE - NOTE
You can use either the slash (/) or backslash (\) as a directory separator. However, the backslash is also used as an escape character, so if you use it as a directory separator, you will generally need to use a double backslash (\\) when you are creating scripts or sending commands to the instrument.

+

For basic information about navigation and directory listing of files on a flash drive, see File system navigation.

+

File descriptor commands for file I/O use a colon (:) to separate the command parts rather than a period (.), like the io commands.

+

File descriptors cannot be passed between nodes in a TSP-Link® system, so the io.open(), fileVar::read(), and fileVar::write commands are not accessible to the TSP-Link system. However, the default input and output files mentioned above allow for the execution of many file I/O operations without any reference to a file descriptor.

+

fileVar:close()

+

fileVar:flush()

+

fileVar:read()

+

fileVar:seek()

+

fileVar:write()

+

fs.chdir()

+

fs.cwd()

+

fs.is_dir()

+

fs.is_file()

+

fs.mkdir()

+

fs.readdir()

+

fs.rmdir()

+

io.close()

+

io.flush()

+

io.input()

+

io.open()

+

io.output()

+

io.read()

+

io.type()

+

io.write()

+

os.remove()

+

os.rename()

+

The following standard I/O commands are not supported:

+ + + + + + + + + + +

File

+

I/O

+
  • fileVar:lines()
  • fileVar:setvbuf()
  • io.lines()
  • io.popen()
+
+ + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14772.htm b/WebHelpDocs/2601B-PULSE/14772.htm new file mode 100644 index 0000000..2a89eb5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14772.htm @@ -0,0 +1,116 @@ + + + + + fileVar:close() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fileVar:close()

+

This function closes the file that is represented by the fileVar variable.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

fileVar:close()

+

+ + + + + + +

fileVar

+

The file descriptor variable to close

+
+

Details

+

This command is equivalent to io.close(fileVar).

+

Note that files are automatically closed when the file descriptors are garbage collected.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

print("\n*** fileVar:close")

+

do

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1")

+

myfile:close()

+

end

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "r")

+

myfile:close()

+

os.remove(fileName)

+

Opens file myfile.txt for writing. If no errors were found while opening, writes Removing file and closes the file.

+
+

Also see

+

fileVar:flush()

+

fileVar:read()

+

fileVar:seek()

+

fileVar:write()

+

io.close()

+

io.open()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14786.htm b/WebHelpDocs/2601B-PULSE/14786.htm new file mode 100644 index 0000000..73fcef4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14786.htm @@ -0,0 +1,118 @@ + + + + + fileVar:flush() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fileVar:flush()

+

This function writes buffered data to a file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

fileVar:flush()

+

+ + + + + + +

fileVar

+

The file descriptor variable to flush

+
+

Details

+

The fileVar:write() or io.write() functions buffer data, which may not be written immediately to the USB flash drive. Use fileVar:flush() to flush this data. Using this function removes the need to close a file after writing to it, allowing the file to be left open to write more data. Data may be lost if the file is not closed or flushed before a script ends.

+

If there is going to be a time delay before more data is written to a file, and you want to keep the file open, flush the file after you write to it to prevent loss of data.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

errorqueue.clear()

+

print("\n*** io.read")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1\n")

+

myfile:flush()

+

myfile:close()

+

do

+

fileHandle = io.input(fileName)

+

value = io.read("*a")

+

print(value)

+

end

+

fileHandle:close()

+

 

+

print(errorqueue.next())

+

Writes data to a USB flash drive.

+
+

Also see

+

fileVar:write()

+

io.open()

+

io.write()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14787.htm b/WebHelpDocs/2601B-PULSE/14787.htm new file mode 100644 index 0000000..c0b2fd2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14787.htm @@ -0,0 +1,165 @@ + + + + + fileVar:read() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fileVar:read()

+

This function reads data from a file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

data1 = fileVar:read()

+

data1 = fileVar:read(format1)

+

data1, data2 = fileVar:read("format1", "format2")

+

data1, ..., datan = fileVar:read("format1", ..., "formatn")

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

data1

+

First data read from the file

+

data2

+

Second data read from the file

+

datan

+

Last data read from the file

+

fileVar

+

The descriptor of the file to be read

+

format1

+

A string or number indicating the first type of data to be read

+

format2

+

A string or number indicating the second type of data to be read

+

formatn

+

A string or number indicating the last type of data to be read

+

...

+

One or more entries (or values) separated by commas

+
+

Details

+

The format parameters may be any of the following:

+

"*n": Returns a number.

+

"*a": Returns the whole file, starting at the current position (returns an empty string if the current file position is at the end of the file).

+

"*l": Returns the next line, skipping the end of line; returns nil if the current file position is at the end of file.

+

n: Returns a string with up to n characters; returns an empty string if n is zero; returns nil if the current file position is at the end of file.

+

If no format parameters are provided, the function will perform as if the function is passed the value "*l".

+

Any number of format parameters may be passed to this command, each corresponding to a returned data value.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

print("fileVar:read")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1")

+

myfile:close()

+

do

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "r")

+

contents = myfile:read("*a")

+

print(contents)

+

end

+

myfile:close()

+

os.remove(fileName)

+

Reads data from the input file.

+
+

Also see

+

fileVar:write()

+

io.input()

+

io.open()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14788.htm b/WebHelpDocs/2601B-PULSE/14788.htm new file mode 100644 index 0000000..05907fc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14788.htm @@ -0,0 +1,144 @@ + + + + + fileVar:seek() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fileVar:seek()

+

This function sets and gets the present position of a file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

position, errorMsg = fileVar:seek()

+

position, errorMsg = fileVar:seek("whence")

+

position, errorMsg = fileVar:seek("whence", offset)

+

+ + + + + + + + + + + + + + + + + + + + + + +

position

+

The new file position, measured in bytes from the beginning of the file

+

errorMsg

+

A string containing the error message

+

fileVar

+

The file descriptor variable

+

whence

+

A string indicating the base against which offset is applied; the default is "cur"

+

offset

+

The intended new position, measured in bytes from a base indicated by whence (default is 0)

+
+

Details

+

The whence parameters may be any of the following:

+

"set": Beginning of file

+

"cur": Current position

+

"end": End of file

+

If an error is encountered, it is logged to the error queue, and the command returns nil and the error string.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

errorqueue.clear()

+

 

+

print("\n*** fileVar:seek")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1")

+

myfile:close()

+

do

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "r")

+

position = myfile:seek("end", -1)

+

print(position)

+

end

+

myfile:close()

+

os.remove(fileName)

+

Get the present position of a file.

+
+

Also see

+

io.open()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14789.htm b/WebHelpDocs/2601B-PULSE/14789.htm new file mode 100644 index 0000000..8e6088f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14789.htm @@ -0,0 +1,146 @@ + + + + + fileVar:write() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fileVar:write()

+

This function writes data to a file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

fileVar:write(data)

+

fileVar:write(data1, data2)

+

fileVar:write(data1, ..., datan)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

fileVar

+

The file descriptor variable

+

data

+

Write all data to the file

+

data1

+

The first data to write to the file

+

data2

+

The second data to write to the file

+

datan

+

The last data to write to the file

+

...

+

One or more entries (or values) separated by commas

+
+

Details

+

This function may buffer data until a flush (fileVar:flush() or io.flush()) or close (fileVar:close() or io.close()) operation is performed.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

errorqueue.clear()

+

 

+

print("\n*** fileVar:write")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

do

+

myfile:write("Line 1")

+

end

+

myfile:close()

+

os.remove(fileName)

+

Write data to a file.

+
+

Also see

+

fileVar:close()

+

fileVar:flush()

+

io.close()

+

io.flush()

+

io.open()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14795.htm b/WebHelpDocs/2601B-PULSE/14795.htm new file mode 100644 index 0000000..17f2d66 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14795.htm @@ -0,0 +1,54 @@ + + + + + Queries and response messages + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Queries and response messages

+

You can use the print(), printbuffer(), and printnumber() functions to query the instrument and generate response messages. The format attributes control how the data is formatted for the print functions used.

+

The localnode commands determine if generated errors are automatically sent and if prompts are generated.

+

format.asciiprecision

+

format.byteorder

+

format.data

+

localnode.prompts

+

localnode.prompts4882

+

localnode.showerrors

+

print()

+

printbuffer()

+

printnumber()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14797.htm b/WebHelpDocs/2601B-PULSE/14797.htm new file mode 100644 index 0000000..cb20491 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14797.htm @@ -0,0 +1,104 @@ + + + + + format.asciiprecision + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

format.asciiprecision

+

This attribute sets the precision (number of digits) for all numbers returned in the ASCII format.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

No

+

Instrument reset
Recall setup

+

Not saved

+

6

+
+

Usage

+

precision = format.asciiprecision

+

format.asciiprecision = precision

+

+ + + + + + +

precision

+

A number representing the number of digits to be printed for numbers printed with the print(), printbuffer(), and printnumber() functions; must be a number between 1 and 16

+
+

Details

+

This attribute specifies the precision (number of digits) for numeric data printed with the print(), printbuffer(), and printnumber() functions. The format.asciiprecision attribute is only used with the ASCII format. The precision value must be a number from 0 to 16.

+

Note that the precision is the number of significant digits printed. There is always one digit to the left of the decimal point; be sure to include this digit when setting the precision.

+

Example

+

+ + + + + + +

format.asciiprecision = 10

+

x = 2.54

+

printnumber(x)

+

format.asciiprecision = 3

+

printnumber(x)

+

Output:

+

2.540000000e+00

+

 

+

2.54e+00

+
+

Also see

+

format.byteorder

+

format.data

+

print()

+

printbuffer()

+

printnumber()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14801.htm b/WebHelpDocs/2601B-PULSE/14801.htm new file mode 100644 index 0000000..3d9dfec --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14801.htm @@ -0,0 +1,104 @@ + + + + + format.byteorder + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

format.byteorder

+

This attribute sets the binary byte order for the data that is printed using the printnumber() and printbuffer() functions.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Not saved

+

1 (format.LITTLEENDIAN)

+
+

Usage

+

order = format.byteorder

+

format.byteorder = order

+

+ + + + + + +

order

+

Byte order value as follows:

+
  • Most significant byte first: 0, format.NORMAL, format.NETWORK, or format.BIGENDIAN
  • Least significant byte first: 1, format.SWAPPED or format.LITTLEENDIAN
+

Details

+

This attribute selects the byte order in which data is written when you are printing data values with the printnumber() and printbuffer() functions. The byte order attribute is only used with the format.SREAL, format.REAL, format.REAL32, and format.REAL64 data formats.

+

format.NORMAL, format.BIGENDIAN, and format.NETWORK select the same byte order. format.SWAPPED and format.LITTLEENDIAN select the same byte order. Selecting which to use is a matter of preference.

+

Select the format.SWAPPED or format.LITTLEENDIAN byte order when sending data to a computer with a Microsoft Windows operating system.

+

Example

+

+ + + + + + +

x = 1.23

+

format.data = format.REAL32

+

format.byteorder = format.LITTLEENDIAN

+

printnumber(x)

+

format.byteorder = format.BIGENDIAN

+

printnumber(x)

+

Output depends on the terminal program you use, but will look something like:

+

#0¤p??

+

#0??p¤

+
+

Also see

+

format.asciiprecision

+

format.data

+

printbuffer()

+

printnumber()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14803.htm b/WebHelpDocs/2601B-PULSE/14803.htm new file mode 100644 index 0000000..15abb51 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14803.htm @@ -0,0 +1,107 @@ + + + + + format.data + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

format.data

+

This attribute sets the data format for data that is printed using the printnumber() and printbuffer() functions.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

No

+

Instrument reset
Recall setup

+

Not saved

+

1 (format.ASCII)

+
+

Usage

+

value = format.data

+

format.data = value

+

+ + + + + + +

value

+

The format to use for data, set to one of the following values:

+
  • ASCII format: 1 or format.ASCII
  • Single-precision IEEE Std 754 binary format: 2, format.SREAL, or format.REAL32
  • Double-precision IEEE Std 754 binary format: 3, format.REAL, format.REAL64, or format.DREAL
+

Details

+

The precision of numeric values can be controlled with the format.asciiprecision attribute. The byte order of format.SREAL, format.REAL, format.REAL32, and format.REAL64 can be selected with the format.byteorder attribute.

+

REAL32 and SREAL select the same single precision format. REAL and REAL64 select the same double precision format. They are alternative identifiers. Selecting which to use is a matter of preference.

+

The IEEE Std 754 binary formats use four bytes for single-precision values and eight bytes for double-precision values.

+

When data is written with any of the binary formats, the response message starts with #0 and ends with a new line. When data is written with the ASCII format, elements are separated with a comma and space.

+

VARIABLE - NOTE
Binary formats are not intended to be interpreted by humans.

+

Example

+

+ + + + + + +

format.asciiprecision = 10

+

x = 3.14159265

+

format.data = format.ASCII

+

printnumber(x)

+

format.data = format.REAL64

+

printnumber(x)

+

Output a number represented by x in ASCII using a precision of 10, then output the same number in binary using double precision format.

+

Output:

+

3.141592650e+00

+

#0ñÔÈSû! @

+
+

Also see

+

format.asciiprecision

+

format.byteorder

+

printbuffer()

+

printnumber()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14808.htm b/WebHelpDocs/2601B-PULSE/14808.htm new file mode 100644 index 0000000..766d901 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14808.htm @@ -0,0 +1,114 @@ + + + + + fs.chdir() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fs.chdir()

+

This function sets the current working directory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

workingDirectory = fs.chdir("path")

+

+ + + + + + + + + + +

workingDirectory

+

Returned value containing the working path

+

path

+

A string indicating the new working directory path

+
+

Details

+

The new working directory path may be absolute or relative to the current working directory.

+

An error is logged to the error queue if the given path does not exist.

+

Example

+

+ + + + + + + + +

if fs.is_dir("/usb1/temp") == true then

+

  fs.chdir("/usb1/temp")

+

  testPath = fs.cwd()

+

  print(testPath)

+

else

+

  testPath = fs.cwd()

+

  print(testPath)

+

end

+

Insert a USB flash drive into the front panel of the instrument.

+

Verify that /usb1/temp is a directory and change it to be the current working directory.

+

Set the variable for the current working directory to be testPath.

+

The return should be:

+

/usb1/temp

+

If /usb1/temp is not a directory, set the variable for the current working directory to be testPath.

+

The return should be:

+

/usb1

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14810.htm b/WebHelpDocs/2601B-PULSE/14810.htm new file mode 100644 index 0000000..7ff3848 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14810.htm @@ -0,0 +1,105 @@ + + + + + fs.cwd() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fs.cwd()

+

This function returns the absolute path of the current working directory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

path = fs.cwd()

+

+ + + + + + +

path

+

The absolute path of the current working directory

+
+

Example

+

+ + + + + + + + +

if fs.is_dir("/usb1/temp") == true then

+

  fs.chdir("/usb1/temp")

+

  testPath = fs.cwd()

+

  print(testPath)

+

else

+

  testPath = fs.cwd()

+

  print(testPath)

+

end

+

Insert a USB flash drive into the front panel of the instrument.

+

Verify that /usb1/temp is a directory and change it to be the current working directory.

+

Set the variable for the current working directory to be testPath.

+

The return should be:

+

/usb1/temp

+

If /usb1/temp is not a directory, set the variable for the current working directory to be testPath.

+

The return should be:

+

/usb1

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14811.htm b/WebHelpDocs/2601B-PULSE/14811.htm new file mode 100644 index 0000000..bd4e8e5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14811.htm @@ -0,0 +1,116 @@ + + + + + fs.is_dir() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fs.is_dir()

+

This function tests whether or not the specified path refers to a directory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

status = fs.is_dir("path")

+

+ + + + + + + + + + +

status

+

Whether or not the given path is a directory (true or false)

+

path

+

The path of the file system entry to test

+
+

Details

+

The file system path may be absolute or relative to the current working system path.

+

Example 1

+

+ + + + + + + + +

print("Is directory: ", fs.is_dir("/usb1/"))

+

Because /usb1/ is always the root directory of an inserted flash drive, you can use this command to verify that USB flash drive is inserted.

+
+

Example 2

+

+ + + + + + + + +

if fs.is_dir("/usb1/temp") == false then

+

    fs.mkdir("/usb1/temp")

+

end

+

Insert a USB flash drive into the front panel of the instrument.

+

Check to see if the temp directory exists.

+

If it does not exist, create a directory named temp.

+
+

Also see

+

fs.is_file()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14812.htm b/WebHelpDocs/2601B-PULSE/14812.htm new file mode 100644 index 0000000..0f2f550 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14812.htm @@ -0,0 +1,104 @@ + + + + + fs.mkdir() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fs.mkdir()

+

This function creates a directory at the specified path.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

path = fs.mkdir("newPath")

+

+ + + + + + + + + + +

path

+

The returned path of the new directory

+

newpath

+

Location (path) of where to create the new directory

+
+

Details

+

The directory path may be absolute or relative to the current working directory.

+

An error is logged to the error queue if the parent folder of the new directory does not exist, or if a file system entry already exists at the given path.

+

Example

+

+ + + + + + + + +

if fs.is_dir("/usb1/temp") == false then

+

    fs.mkdir("/usb1/temp")

+

end

+

Insert a USB flash drive into the front panel of the instrument.

+

Check to see if the temp directory exists.

+

If it does not exist, create a directory named temp.

+
+

Also see

+

fs.rmdir()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14814.htm b/WebHelpDocs/2601B-PULSE/14814.htm new file mode 100644 index 0000000..d815e36 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14814.htm @@ -0,0 +1,110 @@ + + + + + fs.readdir() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fs.readdir()

+

This function returns a list of the file system entries in the directory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

files = fs.readdir("path")

+

+ + + + + + + + + + +

files

+

A table containing the names of all the file system entries in the specified directory

+

path

+

The directory path

+
+

Details

+

The directory path may be absolute or relative to the current working directory.

+

This command is nonrecursive. For example, entries in subfolders are not returned.

+

An error is logged to the error queue if the given path does not exist or does not represent a directory.

+

Example

+

+ + + + + + + + +

rootDirectory = "/usb1/"

+

entries = fs.readdir(rootDirectory)

+

count = table.getn(entries)

+

print("Found a total of "..count.." files and directories")

+

for i = 1, count do

+

print(entries[i])

+

end

+

Insert a USB flash drive into the front panel of the instrument.

+

Set rootDirectory to be the USB port.

+

Set entries as the variable for the file system entries in rootDirectory.

+

Return the number of files and directories in the directory.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14815.htm b/WebHelpDocs/2601B-PULSE/14815.htm new file mode 100644 index 0000000..f2a8108 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14815.htm @@ -0,0 +1,104 @@ + + + + + fs.rmdir() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fs.rmdir()

+

This function removes a directory from the file system.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

fs.rmdir("path")

+

+ + + + + + +

path

+

The path of the directory to remove

+
+

Details

+

This path may be absolute or relative to the present working directory.

+

An error is logged to the error queue if the given path does not exist or does not represent a directory. An error is also logged if the directory is not empty.

+

Example

+

+ + + + + + + + +

rootDirectory = "/usb1/"

+

tempDirectoryName = "temp"

+

if fs.is_dir(rootDirectory..tempDirectoryName) == false then

+

    fs.mkdir(rootDirectory..tempDirectoryName)

+

end

+

fs.rmdir(rootDirectory..tempDirectoryName)

+

Insert a USB flash drive into the front panel of the instrument.

+

Set rootDirectory to be the USB port.

+

Set tempDirectoryName to be equivalent to temp.

+

Check to see if tempDirectoryName exists.

+

If it does not exist, create a directory named temp.

+

Remove the directory.

+
+

Also see

+

fs.mkdir()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14824.htm b/WebHelpDocs/2601B-PULSE/14824.htm new file mode 100644 index 0000000..8d06e95 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14824.htm @@ -0,0 +1,102 @@ + + + + + fs.is_file() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

fs.is_file()

+

Tests whether the specified path refers to a file (as opposed to a directory).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

status = fs.is_file("path")

+

+ + + + + + + + + + +

status

+

true if the given path is a file; otherwise, false

+

path

+

The path of the file system entry to test

+
+

Details

+

The file system path may be absolute or relative to the current working system path.

+

Example

+

+ + + + + + + + +

rootDirectory = "/usb1/"

+

print("Is file: ", fs.is_file(rootDirectory))

+

Insert a USB flash drive into the front panel of the instrument.

+

Set rootDirectory to be the USB port.

+

Check to see if rootDirectory is a file. Because rootDirectory was set up as a directory, the return is false.

+
+

Also see

+

fs.is_dir()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14859.htm b/WebHelpDocs/2601B-PULSE/14859.htm new file mode 100644 index 0000000..1f79058 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14859.htm @@ -0,0 +1,45 @@ + + + + + GPIB + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

GPIB

+

This attribute stores the GPIB address.

+

gpib.address

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14860.htm b/WebHelpDocs/2601B-PULSE/14860.htm new file mode 100644 index 0000000..534a210 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14860.htm @@ -0,0 +1,100 @@ + + + + + gpib.address + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

gpib.address

+

This attribute contains the GPIB address.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

No

+

Not applicable

+

Nonvolatile memory

+

26

+
+

Usage

+

address = gpib.address

+

gpib.address = address

+

+ + + + + + +

address

+

The GPIB address of the instrument (1 to 30)

+
+

Details

+

The address can be set to any address value from 1 to 30. However, the address must be unique in the system. It cannot conflict with an address that is assigned to another instrument or to the GPIB controller.

+

A new GPIB address takes effect when the command to change it is processed. If there are response messages in the output queue when this command is processed, they must be read at the new address.

+

If command messages are being queued (sent before this command has executed), the new settings may take effect in the middle of a subsequent command message, so care should be exercised when setting this attribute from the GPIB interface.

+

You should allow sufficient time for the command to be processed before attempting to communicate with the instrument again.

+

The reset() function does not affect the GPIB address.

+

Example

+

+ + + + + + +

gpib.address = 26

+

address = gpib.address

+

print(address)

+

Sets the GPIB address and reads the address.

+

Output:

+

26

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14868.htm b/WebHelpDocs/2601B-PULSE/14868.htm new file mode 100644 index 0000000..a880781 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14868.htm @@ -0,0 +1,99 @@ + + + + + io.close() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.close()

+

This function closes a file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes (see Details)

+

 

+

 

+

 

+
+

Usage

+

io.close()

+

io.close(file)

+

+ + + + + + +

file

+

The descriptor of the file to close

+
+

Details

+

If a file is not specified, the default output file closes.

+

Only io.close(), used without specifying a parameter, can be accessed from a remote node.

+

Example

+

+ + + + + + + + +

testFile, testError = io.open("testfile.txt", "w")

+

if nil == testError then

+

testFile:write("This is my test file")

+

io.close(testFile)

+

end

+

Opens file testfile.txt for writing. If no errors were found while opening, writes "This is my test file" and closes the file.

+
+

Also see

+

io.open()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14870.htm b/WebHelpDocs/2601B-PULSE/14870.htm new file mode 100644 index 0000000..7372888 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14870.htm @@ -0,0 +1,75 @@ + + + + + io.flush() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.flush()

+

This function saves buffered data to a file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

io.flush()

+

Details

+

You must use the io.flush() or io.close() functions to write data to the file system.

+

VARIABLE - NOTE
Data is not automatically written to a file when you use the io.write() function. The io.write() function buffers data; it may not be written to the USB flash drive immediately. Use the io.flush() function to immediately write buffered data to the drive.

+

This function only flushes the default output file.

+

Using this command removes the need to close a file after writing to it and allows it to be left open to write more data. Data may be lost if the file is not closed or flushed before an application ends. To prevent the loss of data if there is going to be a time delay before more data is written (and when you want to keep the file open and not close it), flush the file after writing to it.

+

Also see

+

fileVar:flush()

+

fileVar:write()

+

io.write()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14872.htm b/WebHelpDocs/2601B-PULSE/14872.htm new file mode 100644 index 0000000..a7993fd --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14872.htm @@ -0,0 +1,115 @@ + + + + + io.open() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.open()

+

This function opens a file for later reference.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

fileVar, errorMsg = io.open("path")

+

fileVar, errorMsg = io.open("path", "mode")

+

+ + + + + + + + + + + + + + + + + + +

fileVar

+

The descriptor of the opened file

+

errorMsg

+

Indicates whether an error was encountered while processing the function

+

path

+

The path of the file to open

+

mode

+

A string representing the intended access mode ("r" = read, "w" = write, and "a" = append)

+
+

Details

+

The path to the file to open may be absolute or relative to the current working directory. If you successfully open the file, errorMsg is nil and fileVar has the descriptor that can be used to access the file.

+

If an error is encountered, the command returns nil for fileVar and an error string.

+

Example

+

+ + + + + + +

testFile, testError = io.open("testfile.txt", "w")

+

if testError == nil then

+

testFile:write("This is my test file")

+

io.close(testFile)

+

end

+

Opens file testfile.txt for writing. If no errors were found while opening, writes "This is my test file" and closes the file.

+
+

Also see

+

io.close()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14873.htm b/WebHelpDocs/2601B-PULSE/14873.htm new file mode 100644 index 0000000..05c9aea --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14873.htm @@ -0,0 +1,124 @@ + + + + + io.output() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.output()

+

This function assigns a previously opened file or opens a new file as the default output file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes (see Details)

+

 

+

 

+

 

+
+

Usage

+

fileVar = io.output()

+

fileVar = io.output("newfile")

+

+ + + + + + + + + + +

fileVar

+

The descriptor of the output file or an error message (if the function fails)

+

newfile

+

A file descriptor to assign (or the path of a file to open) as the default output file

+
+

Details

+

The path of the file to open may be absolute or relative to the current working directory.

+

When accessed from a remote node using the TSP-Link network, this command does not accept a file descriptor parameter and does not return a value.

+

If the function fails, an error message is returned.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

errorqueue.clear()

+

 

+

print("\n*** io.output")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1")

+

myfile:close()

+

do

+

fileHandle = io.output(fileName)

+

print(fileHandle)

+

end

+

io.close(fileHandle)

+

print(fileHandle)

+

os.remove(fileName)

+

Assign the file to be the default output file.

+
+

Also see

+

io.input()

+

io.open()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14874.htm b/WebHelpDocs/2601B-PULSE/14874.htm new file mode 100644 index 0000000..dcd1f76 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14874.htm @@ -0,0 +1,192 @@ + + + + + io.read() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.read()

+

This function reads data from the default input file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

data1 = io.read()

+

data1 = io.read("format1")

+

data1, data2 = io.read("format1", "format2")

+

data1, ..., dataN = io.read("format1", ..., "formatN")

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

data1

+

The data read from the file

+

data2

+

The data read from the file

+

dataN

+

The data read from the file; the number of return values matches the number of format values given

+

format1

+

A string or number indicating the type of data to be read

+

format2

+

A string or number indicating the type of data to be read

+

formatN

+

A string or number indicating the type of data to be read

+

...

+

One or more entries (or values) separated by commas

+
+

Details

+

The format parameters may be any of the following:

+

+ + + + + + + + + + + + + + + + + + + + + + +

Format parameter

+

Description

+

"*n"

+

Returns a number

+

"*a"

+

Returns the whole file, starting at the present position; returns an empty string if it is at the end of file

+

"*l"

+

Returns the next line, skipping the end of line; returns nil if the present file position is at the end of file

+

N

+

Returns a string with up to N characters; returns an empty string if N is zero (0); returns nil if the present file position is at the end of file

+
+

Any number of format parameters may be passed to this command, each corresponding to a returned data value.

+

If no format parameters are provided, the function will perform as if the function was passed the value "*l".

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

errorqueue.clear()

+

 

+

-- io.read

+

print("\n*** io.read")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1\n")

+

myfile:flush()

+

myfile:close()

+

do

+

fileHandle = io.input(fileName)

+

value = io.read("*a")

+

print(value)

+

end

+

fileHandle:close()

+

 

+

print(errorqueue.next())

+

Read data from the default input file.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14875.htm b/WebHelpDocs/2601B-PULSE/14875.htm new file mode 100644 index 0000000..dfd26e3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14875.htm @@ -0,0 +1,122 @@ + + + + + io.type() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.type()

+

This function checks whether or not a given object is a file handle.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

type = io.type(obj)

+

+ + + + + + + + + + +

type

+

Indicates whether the object is an open file handle

+

obj

+

Object to check

+
+

Details

+

Returns the string "file" if the object is an open file handle. If it is not an open file handle, nil is returned.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

errorqueue.clear()

+

 

+

print("\n*** io.type")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1")

+

myfile:close()

+

do

+

fileHandle = io.output(fileName)

+

state = io.type(fileHandle)

+

print(state)

+

end

+

io.close(fileHandle)

+

local state = io.type(fileHandle)

+

print(state)

+

os.remove(fileName)

+

Check whether or not fileName is a file handle.

+
+

Also see

+

io.open()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14877.htm b/WebHelpDocs/2601B-PULSE/14877.htm new file mode 100644 index 0000000..7ec9593 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14877.htm @@ -0,0 +1,135 @@ + + + + + io.write() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.write()

+

This function writes data to the default output file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

io.write()

+

io.write(data1)

+

io.write(data1, data2)

+

io.write(data1, ..., dataN)

+

+ + + + + + + + + + + + + + + + + + +

data1

+

The data to be written

+

data2

+

The data to be written

+

dataN

+

The data to be written

+

...

+

One or more values separated by commas

+
+

Details

+

All data parameters must be either strings or numbers.

+

VARIABLE - NOTE
Data is not immediately written to a file when you use the io.write() function. The io.write() function buffers data; it may not be written to the USB flash drive immediately. Use the io.flush() function to immediately write buffered data to the drive.

+

Example

+

+ + + + + + + + +

local fileName = "/usb1/myfile.txt"

+

 

+

if fs.is_file(fileName) then

+

os.remove(fileName)

+

print("Removing file")

+

else

+

print("Nothing removed")

+

end

+

 

+

errorqueue.clear()

+

 

+

print("\n*** io.write")

+

myfile, myfile_err, myfile_errnum = io.open(fileName, "w")

+

myfile:write("Line 1")

+

myfile:close()

+

do

+

fileHandle = io.output(fileName)

+

io.write("Line 2")

+

end

+

io.close(fileHandle)

+

os.remove(fileName)

+

Writes data to the default output file.

+
+

Also see

+

io.flush()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14890.htm b/WebHelpDocs/2601B-PULSE/14890.htm new file mode 100644 index 0000000..591b3a3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14890.htm @@ -0,0 +1,84 @@ + + + + + lan.applysettings() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.applysettings()

+

This function re-initializes the LAN interface with new settings.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

lan.applysettings()

+

Details

+

Disconnects all existing LAN connections to the instrument and re-initializes the LAN with the present configuration settings.

+

This function initiates a background operation. LAN configuration could be a lengthy operation. Although the function returns immediately, the LAN initialization continues to run in the background.

+

Even though the LAN configuration settings may not have changed since the LAN was last connected, new settings may take effect due to the dynamic nature of dynamic host configuration protocol (DHCP) or dynamic link local addressing (DLLA) configuration.

+

Re-initialization takes effect even if the configuration has not changed since the last time the instrument connected to the LAN.

+

Example

+

+ + + + + + +

lan.applysettings()

+

Re-initialize the LAN interface with new settings.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14891.htm b/WebHelpDocs/2601B-PULSE/14891.htm new file mode 100644 index 0000000..40cc811 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14891.htm @@ -0,0 +1,97 @@ + + + + + lan.autoconnect + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.autoconnect

+

This attribute is used to enable or disable link monitoring.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

1 (lan.ENABLE)

+
+

Usage

+

state = lan.autoconnect

+

lan.autoconnect = state

+

+ + + + + + +

state

+

LAN link monitoring state:

+

1 or lan.ENABLE: Enables automatic link reconnection and monitoring

+

0 or lan.DISABLE: Disables automatic link reconnection and monitoring

+
+

Details

+

This attribute sets the LAN link monitoring and automatic connection state.

+

When this is set to lan.ENABLE, all connections are closed if the link to the LAN is lost for more than the time specified by lan.linktimeout.

+

Set this attribute to lan.ENABLE to automatically reset the LAN connection after the LAN link is established.

+

Example

+

+ + + + + + +

lan.autoconnect = lan.ENABLE

+

Enable LANK link monitoring.

+
+

Also see

+

lan.linktimeout

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14892.htm b/WebHelpDocs/2601B-PULSE/14892.htm new file mode 100644 index 0000000..f31bca2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14892.htm @@ -0,0 +1,96 @@ + + + + + lan.linktimeout + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.linktimeout

+

This attribute contains the LAN link timeout period.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

20 (20 s)

+
+

Usage

+

timeout = lan.linktimeout

+

lan.linktimeout = timeout

+

+ + + + + + +

timeout

+

The LAN link monitor time-out period (in seconds)

+
+

Details

+

You must enable the command lan.autoconnect before you can use this attribute.

+

The timeout value represents the amount of time that passes before the instrument disconnects from the LAN due to the loss of the LAN link integrity.

+

The LAN interface does not disconnect if the connection to the LAN is reestablished before the timeout value expires.

+

If the LAN link integrity is not restored before the timeout value expires, the instrument begins to monitor for a new connection.

+

Example

+

+ + + + + + +

print(lan.linktimeout)

+

Outputs the present LAN link timeout setting.

+
+

Also see

+

lan.autoconnect

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14893.htm b/WebHelpDocs/2601B-PULSE/14893.htm new file mode 100644 index 0000000..ba45cd6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14893.htm @@ -0,0 +1,93 @@ + + + + + lan.lxidomain + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.lxidomain

+

This attribute contains the LXI domain.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

0

+
+

Usage

+

domain = lan.lxidomain

+

lan.lxidomain = domain

+

+ + + + + + +

domain

+

The LXI domain number (0 to 255)

+
+

Details

+

This attribute sets the LXI domain number.

+

All outgoing LXI packets are generated with this domain number. All inbound LXI packets are ignored unless they have this domain number.

+

Example

+

+ + + + + + +

print(lan.lxidomain)

+

Displays the LXI domain.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14894.htm b/WebHelpDocs/2601B-PULSE/14894.htm new file mode 100644 index 0000000..1bee53a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14894.htm @@ -0,0 +1,81 @@ + + + + + lan.nagle + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.nagle

+

This attribute controls the state of the LAN Nagle algorithm.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Power cycle

+

Not saved

+

0 (lan.DISABLE)

+
+

Usage

+

state = lan.nagle

+

lan.nagle = state

+

+ + + + + + +

state

+

The state of the Nagle algorithm:

+
  • 1 or lan.ENABLE: Enable the LAN Nagle algorithm for TCP connections
  • 0 or lan.DISABLE: Disable the Nagle algorithm for TCP connections
+

Details

+

This attribute enables or disables the use of the LAN Nagle algorithm on transmission control protocol (TCP) connections.

+

Also see

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14895.htm b/WebHelpDocs/2601B-PULSE/14895.htm new file mode 100644 index 0000000..8468dbb --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14895.htm @@ -0,0 +1,71 @@ + + + + + lan.reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.reset()

+

This function resets the LAN interface.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

lan.reset()

+

Details

+

This function resets the LAN interface. It performs the commands lan.restoredefaults() and lan.applysettings().

+

Also see

+

lan.applysettings()

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14896.htm b/WebHelpDocs/2601B-PULSE/14896.htm new file mode 100644 index 0000000..69ef59e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14896.htm @@ -0,0 +1,192 @@ + + + + + lan.restoredefaults() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.restoredefaults()

+

This function resets LAN settings to default values.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

lan.restoredefaults()

+

Details

+

The settings that are restored are shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Settings that are restored to default

+

Attribute

+

Default setting

+

lan.autoconnect

+

lan.ENABLE

+

lan.config.dns.address[N]

+

"0.0.0.0"

+

lan.config.dns.domain

+

""

+

lan.config.dns.dynamic

+

lan.ENABLE

+

lan.config.dns.hostname

+

"K-<model number>-<serial number>"

+

lan.config.dns.verify

+

lan.ENABLE

+

lan.config.duplex

+

lan.FULL

+

lan.config.gateway

+

"0.0.0.0"

+

lan.config.ipaddress

+

"0.0.0.0"

+

lan.config.method

+

lan.AUTO

+

lan.config.speed

+

100

+

lan.config.subnetmask

+

"255.255.255.0"

+

lan.linktimeout

+

20 (seconds)

+

lan.lxidomain

+

0

+

lan.nagle

+

lan.DISABLE

+

lan.timedwait

+

20 (seconds)

+
+

This command is run when lan.reset() is sent.

+

Example

+

+ + + + + + +

lan.restoredefaults()

+

Restores the LAN defaults.

+
+

Also see

+

lan.reset()

+

localnode.password

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14897.htm b/WebHelpDocs/2601B-PULSE/14897.htm new file mode 100644 index 0000000..b81afac --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14897.htm @@ -0,0 +1,93 @@ + + + + + lan.timedwait + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.timedwait

+

This attribute contains the LAN timed-wait state interval.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

20 (20 s)

+
+

Usage

+

timeout = lan.timedwait

+

lan.timedwait = timeout

+

+ + + + + + +

timeout

+

The LAN timed-wait state interval in seconds

+
+

Details

+

This attribute controls the amount of time that resources are allocated to closed TCP connections. When a TCP connection is closed, the connection is put in a timed-wait state and resources remain allocated for the connection until the timed-wait state ends. During the timed-wait interval, the instrument processes delayed packets that arrive after the connection is closed.

+

Use this attribute to tailor the timed-wait state interval for the instrument.

+

Example

+

+ + + + + + +

lan.timedwait = 30

+

Set the amount of time resources are allocated to TCP connection to 30 s.

+
+

Also see

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14898.htm b/WebHelpDocs/2601B-PULSE/14898.htm new file mode 100644 index 0000000..2ec7080 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14898.htm @@ -0,0 +1,106 @@ + + + + + lan.config.dns.address[N] + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.dns.address[N]

+

Configures DNS server IP addresses.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

"0.0.0.0"

+
+

Usage

+

dnsAddress = lan.config.dns.address[N]

+

lan.config.dns.address[N] = "dnsAddress"

+

+ + + + + + + + + + +

dnsAddress

+

DNS server IP address

+

N

+

Entry index (1 or 2)

+
+

Details

+

This attribute is an array of DNS (domain name system) server addresses. These addresses take priority for DNS lookups and are consulted before any server addresses that are obtained using DHCP. This allows local DNS servers to be specified that take priority over DHCP-configured global DNS servers.

+

You can specify up to two addresses. The address specified by 1 is consulted first for DNS lookups. dnsAddress must be a string specifying the IP address of the DNS server in dotted decimal notation.

+

Unused entries are returned as "0.0.0.0" when read. To disable an entry, set its value to "0.0.0.0" or the empty string "".

+

Although only two addresses may be manually specified here, the instrument will use up to three DNS server addresses. If two are specified here, only one that is given by a DHCP server is used. If no entries are specified here, up to three addresses that are given by a DHCP server are used.

+

Example

+

+ + + + + + +

dnsaddress = "164.109.48.173"

+

lan.config.dns.address[1] = dnsaddress

+

Set the DNS address 1 to "164.109.48.173"

+
+

Also see

+

lan.config.dns.domain

+

lan.config.dns.dynamic

+

lan.config.dns.hostname

+

lan.config.dns.verify

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14899.htm b/WebHelpDocs/2601B-PULSE/14899.htm new file mode 100644 index 0000000..cf1ce81 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14899.htm @@ -0,0 +1,97 @@ + + + + + lan.config.dns.domain + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.dns.domain

+

Configures the dynamic DNS domain.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

""

+
+

Usage

+

domain = lan.config.dns.domain

+

lan.config.dns.domain = "domain"

+

+ + + + + + +

domain

+

Dynamic DNS registration domain; use a string of 255 characters or less

+
+

Details

+

This attribute holds the domain to request during dynamic DNS registration. Dynamic DNS registration works with DHCP to register the domain specified in this attribute with the DNS server.

+

The length of the fully qualified host name (combined length of the domain and host name with separator characters) must be less than or equal to 255 characters. Although up to 255 characters are allowed, you must make sure the combined length is also no more than 255 characters.

+

Example

+

+ + + + + + +

print(lan.config.dns.domain)

+

Outputs the present dynamic DNS domain. For example, if the domain is "Matrix", the response would be:

+

Matrix

+
+

Also see

+

lan.config.dns.dynamic

+

lan.config.dns.hostname

+

lan.config.dns.verify

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14900.htm b/WebHelpDocs/2601B-PULSE/14900.htm new file mode 100644 index 0000000..072fc36 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14900.htm @@ -0,0 +1,95 @@ + + + + + lan.config.dns.dynamic + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.dns.dynamic

+

Enables or disables the dynamic DNS registration.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

1 (lan.ENABLE)

+
+

Usage

+

state = lan.config.dns.dynamic

+

lan.config.dns.dynamic = state

+

+ + + + + + +

state

+

The dynamic DNS registration state. It may be one of the following values:

+
  • 1 or lan.ENABLE: Enabled
  • 0 or lan.DISABLE: Disabled
+

Details

+

Dynamic DNS registration works with DHCP to register the host name with the DNS server. The host name is specified in the lan.config.dns.hostname attribute.

+

Example

+

+ + + + + + +

print(lan.config.dns.dynamic)

+

Outputs the dynamic registration state.

+

If dynamic DNS registration is enabled, the response is:

+

1.00000e+00

+
+

Also see

+

lan.config.dns.hostname

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14902.htm b/WebHelpDocs/2601B-PULSE/14902.htm new file mode 100644 index 0000000..f51b0ad --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14902.htm @@ -0,0 +1,95 @@ + + + + + lan.config.dns.verify + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.dns.verify

+

This attribute defines the DNS host name verification state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

1 (lan.ENABLE)

+
+

Usage

+

state = lan.config.dns.verify

+

lan.config.dns.verify = state

+

+ + + + + + +

state

+

DNS hostname verification state:

+
  • 1 or lan.ENABLE: DNS host name verification enabled
  • 0 or lan.DISABLE: DNS host name verification disabled
+

Details

+

When this is enabled, the instrument performs DNS lookups to verify that the DNS host name matches the value specified by lan.config.dns.hostname.

+

Example

+

+ + + + + + +

print(lan.config.dns.verify)

+

Outputs the present DNS host name verification state.

+

If it is enabled, the output is:

+

1.00000e+00

+
+

Also see

+

lan.config.dns.hostname

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14903.htm b/WebHelpDocs/2601B-PULSE/14903.htm new file mode 100644 index 0000000..be93234 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14903.htm @@ -0,0 +1,92 @@ + + + + + lan.config.duplex + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.duplex

+

This attribute defines the LAN duplex mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

1 (lan.FULL)

+
+

Usage

+

duplex = lan.config.duplex

+

lan.config.duplex = duplex

+

+ + + + + + +

duplex

+

LAN duplex setting can be one of the following values:

+
  • 1 or lan.FULL: Selects full-duplex operation
  • 0 or lan.HALF: Selects half-duplex operation
+

Details

+

This attribute does not indicate the actual setting currently in effect. Use the lan.status.duplex attribute to determine the present operating state of the LAN.

+

Example

+

+ + + + + + +

lan.config.duplex = lan.FULL

+

Select the LAN duplex mode to full.

+
+

Also see

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14904.htm b/WebHelpDocs/2601B-PULSE/14904.htm new file mode 100644 index 0000000..6702337 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14904.htm @@ -0,0 +1,96 @@ + + + + + lan.config.gateway + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.gateway

+

This attribute contains the LAN default gateway address.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

"0.0.0.0"

+
+

Usage

+

gatewayAddress = lan.config.gateway

+

lan.config.gateway = "gatewayAddress"

+

+ + + + + + +

gatewayAddress

+

LAN default gateway address; must be a string specifying the default gateway’s IP address in dotted decimal notation

+
+

Details

+

This attribute specifies the default gateway IP address to use when manual or DLLA configuration methods are used to configure the LAN. If DHCP is enabled, this setting is ignored.

+

This attribute does not indicate the actual setting that is presently in effect. Use the lan.status.gateway attribute to determine the present operating state of the LAN.

+

The IP address must be formatted in four groups of numbers, each separated by a decimal.

+

Example

+

+ + + + + + +

print(lan.config.gateway)

+

Outputs the default gateway address. For example, you might see the output:

+

192.168.0.1

+
+

Also see

+

lan.restoredefaults()

+

lan.status.gateway

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14905.htm b/WebHelpDocs/2601B-PULSE/14905.htm new file mode 100644 index 0000000..22eff66 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14905.htm @@ -0,0 +1,94 @@ + + + + + lan.config.ipaddress + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.ipaddress

+

This command specifies the LAN IP address.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

"192.168.0.2"

+
+

Usage

+

ipAddress = lan.config.ipaddress

+

lan.config.ipaddress = "ipAddress"

+

+ + + + + + +

ipAddress

+

LAN IP address; must be a string specifying the IP address in dotted decimal notation

+
+

Details

+

This command specifies the LAN IP address to use when the LAN is configured using the manual configuration method. This setting is ignored when DLLA or DHCP is used.

+

This attribute does not indicate the actual setting that is presently in effect. Use the lan.status.ipaddress attribute to determine the present operating state of the LAN.

+

Example

+

+ + + + + + +

ipaddress = lan.config.ipaddress

+

Retrieves the presently set LAN IP address.

+
+

Also see

+

lan.restoredefaults()

+

lan.status.ipaddress

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14906.htm b/WebHelpDocs/2601B-PULSE/14906.htm new file mode 100644 index 0000000..9208095 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14906.htm @@ -0,0 +1,96 @@ + + + + + lan.config.method + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.method

+

This attribute contains the LAN settings configuration method.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

0 (lan.AUTO)

+
+

Usage

+

method = lan.config.method

+

lan.config.method = method

+

+ + + + + + +

method

+

The method for configuring LAN settings; it can be one of the following values:

+
  • 0 or lan.AUTO: Selects automatic sequencing of configuration methods
  • 1 or lan.MANUAL: Use only manually specified configuration settings
+

Details

+

This attribute controls how the LAN IP address, subnet mask, default gateway address, and DNS server addresses are determined.

+

When method is lan.AUTO, the instrument first attempts to configure the LAN settings using dynamic host configuration protocol (DHCP). If DHCP fails, it tries dynamic link local addressing (DLLA). If DLLA fails, it uses the manually specified settings.

+

When method is lan.MANUAL, only the manually specified settings are used. Neither DHCP nor DLLA are attempted.

+

Example

+

+ + + + + + +

print(lan.config.method)

+

Outputs the current method.

+

For example:

+

1.00000e+00

+
+

Also see

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14907.htm b/WebHelpDocs/2601B-PULSE/14907.htm new file mode 100644 index 0000000..06d766d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14907.htm @@ -0,0 +1,95 @@ + + + + + lan.config.speed + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.speed

+

This attribute contains the LAN speed used when restarting in manual configuration mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

100 (100 Mbps)

+
+

Usage

+

speed = lan.config.speed

+

lan.config.speed = speed

+

+ + + + + + +

speed

+

LAN speed setting in Mbps (10 or 100)

+
+

Details

+

This attribute stores the speed that will be used if the LAN is restarted for manual configuration operation.

+

This attribute does not indicate the actual setting presently in effect. Use the lan.status.speed attribute to determine the present operating state of the LAN.

+

The LAN speed is measured in megabits per second (Mbps).

+

Example

+

+ + + + + + +

lan.config.speed = 100

+

Configure LAN speed for 100.

+
+

Also see

+

lan.restoredefaults()

+

lan.status.speed

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14908.htm b/WebHelpDocs/2601B-PULSE/14908.htm new file mode 100644 index 0000000..3bfec8c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14908.htm @@ -0,0 +1,95 @@ + + + + + lan.config.subnetmask + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.subnetmask

+

This attribute contains the LAN subnet mask.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

LAN restore defaults

+

Nonvolatile memory

+

"255.255.255.0"

+
+

Usage

+

mask = lan.config.subnetmask

+

lan.config.subnetmask = "mask"

+

+ + + + + + +

mask

+

String that specifies the LAN subnet mask value in dotted decimal notation

+
+

Details

+

This attribute specifies the LAN subnet mask that will be used when the manual configuration method is used to configure the LAN. This setting is ignored when DLLA or DHCP is used.

+

This attribute does not indicate the actual setting presently in effect. Use the lan.status.subnetmask attribute to determine the present operating state of the LAN.

+

Example

+

+ + + + + + +

print(lan.config.subnetmask)

+

Outputs the LAN subnet mask, such as:

+

255.255.255.0

+
+

Also see

+

lan.restoredefaults()

+

lan.status.subnetmask

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14909.htm b/WebHelpDocs/2601B-PULSE/14909.htm new file mode 100644 index 0000000..1f9019c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14909.htm @@ -0,0 +1,101 @@ + + + + + lan.status.dns.address[N] + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.dns.address[N]

+

This attribute contains the DNS server IP addresses.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

dnsAddress = lan.status.dns.address[N]

+

+ + + + + + + + + + +

dnsAddress

+

DNS server IP address

+

N

+

Entry index (1, 2, or 3)

+
+

Details

+

This attribute is an array of DNS server addresses. The instrument can use up to three addresses.

+

Unused or disabled entries are returned as "0.0.0.0" when read. The dnsAddress returned is a string specifying the IP address of the DNS server in dotted decimal notation.

+

You can only specify two addresses manually. However, the instrument uses up to three DNS server addresses. If two are specified, only the one given by a DHCP server is used. If no entries are specified, up to three address given by a DHCP server are used.

+

The value of lan.status.dns.address[1] is referenced first for all DNS lookups. The values of lan.status.dns.address[2] and lan.status.dns.address[3] are referenced second and third, respectively.

+

Example

+

+ + + + + + +

print(lan.status.dns.address[1])

+

Outputs DNS server address 1, for example:

+

164.109.48.173

+
+

Also see

+

lan.status.dns.name

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14910.htm b/WebHelpDocs/2601B-PULSE/14910.htm new file mode 100644 index 0000000..e282994 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14910.htm @@ -0,0 +1,94 @@ + + + + + lan.status.dns.name + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.dns.name

+

This attribute contains the present DNS fully qualified host name.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

hostName = lan.status.dns.name

+

+ + + + + + +

hostName

+

Fully qualified DNS host name that can be used to connect to the instrument

+
+

Details

+

A fully qualified domain name (FQDN), sometimes referred to as an absolute domain name, is a domain name that specifies its exact location in the tree hierarchy of the Domain Name System (DNS).

+

A FQDN is the complete domain name for a specific computer or host on the LAN. The FQDN consists of two parts: the host name and the domain name.

+

If the DNS host name for an instrument is not found, this attribute stores the IP address in dotted decimal notation.

+

Example

+

+ + + + + + +

print(lan.status.dns.name)

+

Outputs the dynamic DNS host name.

+
+

Also see

+

lan.config.dns.address[N]

+

lan.config.dns.hostname

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14911.htm b/WebHelpDocs/2601B-PULSE/14911.htm new file mode 100644 index 0000000..128fd67 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14911.htm @@ -0,0 +1,90 @@ + + + + + lan.status.duplex + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.duplex

+

This attribute contains the duplex mode presently in use by the LAN interface.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

duplex = lan.status.duplex

+

+ + + + + + +

duplex

+

LAN duplex setting can be one of the following values:

+
  • 0 or lan.HALF: half-duplex operation
  • 1 or lan.FULL: full-duplex operation
+

Example

+

+ + + + + + +

print(lan.status.duplex)

+

Outputs the present LAN duplex mode, such as:

+

1.00000e+00

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14912.htm b/WebHelpDocs/2601B-PULSE/14912.htm new file mode 100644 index 0000000..3a13d2d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14912.htm @@ -0,0 +1,92 @@ + + + + + lan.status.gateway + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.gateway

+

This attribute contains the gateway address presently in use by the LAN interface.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

gatewayAddress = lan.status.gateway

+

+ + + + + + +

gatewayAddress

+

LAN gateway address presently being used

+
+

Details

+

The value of gatewayAddress is a string that indicates the IP address of the gateway in dotted decimal notation.

+

Example

+

+ + + + + + +

print(lan.status.gateway)

+

Outputs the gateway address, such as:

+

192.168.0.1

+
+

Also see

+

lan.config.gateway

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14913.htm b/WebHelpDocs/2601B-PULSE/14913.htm new file mode 100644 index 0000000..30ccf6d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14913.htm @@ -0,0 +1,92 @@ + + + + + lan.status.ipaddress + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.ipaddress

+

This attribute contains the LAN IP address presently in use by the LAN interface.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

ipAddress = lan.status.ipaddress

+

+ + + + + + +

ipAddress

+

LAN IP address specified in dotted decimal notation

+
+

Details

+

The IP address is a character string that represents the IP address assigned to the instrument.

+

Example

+

+ + + + + + +

print(lan.status.ipaddress)

+

Outputs the LAN IP address currently in use, such as:

+

192.168.0.2

+
+

Also see

+

lan.config.ipaddress

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14914.htm b/WebHelpDocs/2601B-PULSE/14914.htm new file mode 100644 index 0000000..2c03e3d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14914.htm @@ -0,0 +1,92 @@ + + + + + lan.status.macaddress + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.macaddress

+

This attribute contains the LAN MAC address.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

macAddress = lan.status.macaddress

+

+ + + + + + +

macAddress

+

The instrument MAC address

+
+

Details

+

The MAC address is a character string representing the MAC address of the instrument in hexadecimal notation. The string includes colons that separate the address octets (see Example).

+

Example

+

+ + + + + + +

print(lan.status.macaddress)

+

Outputs the MAC address of the instrument, for example:

+

08:00:11:00:00:57

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14915.htm b/WebHelpDocs/2601B-PULSE/14915.htm new file mode 100644 index 0000000..a62ab48 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14915.htm @@ -0,0 +1,93 @@ + + + + + lan.status.port.dst + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.port.dst

+

This attribute contains the LAN dead socket termination port number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

port = lan.status.port.dst

+

+ + + + + + +

port

+

Dead socket termination socket port number

+
+

Details

+

This attribute holds the TCP port number used to reset all other LAN socket connections.

+

To reset all LAN connections, open a connection to the DST port number.

+

Example

+

+ + + + + + +

print(lan.status.port.dst)

+

Outputs the LAN dead socket termination port number, such as:

+

5.03000e+03

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14916.htm b/WebHelpDocs/2601B-PULSE/14916.htm new file mode 100644 index 0000000..158059f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14916.htm @@ -0,0 +1,92 @@ + + + + + lan.status.port.rawsocket + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.port.rawsocket

+

This attribute contains the LAN raw socket connection port number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

port = lan.status.port.rawsocket

+

+ + + + + + +

port

+

Raw socket port number

+
+

Details

+

The TCP port number used to connect the instrument and to control the instrument over a raw socket communication interface.

+

Example

+

+ + + + + + +

print(lan.status.port.rawsocket)

+

Outputs the LAN raw socket port number, such as:

+

5.02500e+03

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14917.htm b/WebHelpDocs/2601B-PULSE/14917.htm new file mode 100644 index 0000000..76a51da --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14917.htm @@ -0,0 +1,93 @@ + + + + + lan.status.port.telnet + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.port.telnet

+

This attribute contains the LAN Telnet connection port number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

port = lan.status.port.telnet

+

+ + + + + + +

port

+

Telnet port number

+
+

Details

+

This attribute holds the TCP port number used to connect to the instrument to control it over a Telnet interface.

+

Example

+

+ + + + + + +

print(lan.status.port.telnet)

+

Get the LAN Telnet connection port number.

+

Output:

+

2.30000e+01

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14918.htm b/WebHelpDocs/2601B-PULSE/14918.htm new file mode 100644 index 0000000..725b167 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14918.htm @@ -0,0 +1,92 @@ + + + + + lan.status.port.vxi11 + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.port.vxi11

+

This attribute contains the LAN VXI-11 connection port number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

port = lan.status.port.vxi11

+

+ + + + + + +

port

+

LAN VXI-11 port number

+
+

Details

+

This attribute stores the TCP port number used to connect to the instrument over a VXI-11 interface.

+

Example

+

+ + + + + + +

print(lan.status.port.vxi11)

+

Outputs the VXI-11 number, such as:

+

1.02400e+03

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14919.htm b/WebHelpDocs/2601B-PULSE/14919.htm new file mode 100644 index 0000000..7b7ba52 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14919.htm @@ -0,0 +1,92 @@ + + + + + lan.status.speed + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.speed

+

This attribute contains the LAN speed.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

speed = lan.status.speed

+

+ + + + + + +

speed

+

LAN speed in Mbps, either 10 or 100

+
+

Details

+

This attribute indicates the transmission speed currently in use by the LAN interface.

+

Example

+

+ + + + + + +

print(lan.status.speed)

+

Outputs the transmission speed of the instrument presently in use, such as:

+

1.00000e+02

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14920.htm b/WebHelpDocs/2601B-PULSE/14920.htm new file mode 100644 index 0000000..3facaba --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14920.htm @@ -0,0 +1,92 @@ + + + + + lan.status.subnetmask + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.status.subnetmask

+

This attribute contains the LAN subnet mask that is presently in use by the LAN interface.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

mask = lan.status.subnetmask

+

+ + + + + + +

mask

+

A string specifying the subnet mask in dotted decimal notation

+
+

Details

+

Use this attribute to determine the present operating state of the LAN. This attribute will return the present LAN subnet mask value if the LAN is manually configured, or when DLLA or DHCP is used.

+

Example

+

+ + + + + + +

print(lan.status.subnetmask)

+

Outputs the subnet mask of the instrument that is presently in use, such as:

+

255.255.255.0

+
+

Also see

+

lan.config.subnetmask

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14921.htm b/WebHelpDocs/2601B-PULSE/14921.htm new file mode 100644 index 0000000..34891e5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14921.htm @@ -0,0 +1,99 @@ + + + + + lan.trigger[N].assert() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].assert()

+

This function simulates the occurrence of the trigger and generates the corresponding event ID.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

lan.trigger[N].assert()

+

+ + + + + + +

N

+

The LAN event number (1 to 8)

+
+

Details

+

Generates and sends a LAN trigger packet for the LAN event number specified.

+

Sets the pseudo line state to the appropriate state.

+

The following indexes provide the listed LXI events:

+
  • 1:LAN0
  • 2:LAN1
  • 3:LAN2
  • 8:LAN7

Example

+

+ + + + + + +

lan.trigger[5].assert()

+

Creates a trigger with LAN packet 5.

+
+

Also see

+

lan.lxidomain

+

lan.trigger[N].clear()

+

lan.trigger[N].mode

+

lan.trigger[N].overrun

+

lan.trigger[N].stimulus

+

lan.trigger[N].wait()

+

Understanding hardware value and pseudo line state

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14922.htm b/WebHelpDocs/2601B-PULSE/14922.htm new file mode 100644 index 0000000..1d056e4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14922.htm @@ -0,0 +1,95 @@ + + + + + lan.trigger[N].clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].clear()

+

This function clears the event detector for a LAN trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

lan.trigger[N].clear()

+

+ + + + + + +

N

+

The LAN event number (1 to 8) to clear

+
+

Details

+

The trigger event detector enters the detected state when an event is detected. This function clears a trigger event detector and discards the history of the trigger packet.

+

This function clears all overruns associated with this LAN trigger.

+

Example

+

+ + + + + + +

lan.trigger[5].clear()

+

Clears the event detector with LAN packet 5.

+
+

Also see

+

lan.trigger[N].assert()

+

lan.trigger[N].overrun

+

lan.trigger[N].stimulus

+

lan.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14923.htm b/WebHelpDocs/2601B-PULSE/14923.htm new file mode 100644 index 0000000..2a5aaaf --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14923.htm @@ -0,0 +1,99 @@ + + + + + lan.trigger[N].connect() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].connect()

+

This function prepares the event generator for outgoing trigger events.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

lan.trigger[N].connect()

+

+ + + + + + +

N

+

The LAN event number (1 to 8)

+
+

Details

+

This command prepares the event generator to send event messages. For TCP connections, this opens the TCP connection.

+

The event generator automatically disconnects when either the protocol or IP address for this event is changed.

+

Example

+

+ + + + + + +

lan.trigger[1].protocol = lan.MULTICAST

+

lan.trigger[1].connect()

+

lan.trigger[1].assert()

+

Set the protocol for LAN trigger 1 to be multicast when sending LAN triggers. Then, after connecting the LAN trigger, send a message on LAN trigger 1 by asserting it.

+
+

Also see

+

lan.trigger[N].assert()

+

lan.trigger[N].ipaddress

+

lan.trigger[N].overrun

+

lan.trigger[N].protocol

+

lan.trigger[N].stimulus

+

lan.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14924.htm b/WebHelpDocs/2601B-PULSE/14924.htm new file mode 100644 index 0000000..bc85727 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14924.htm @@ -0,0 +1,103 @@ + + + + + lan.trigger[N].connected + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].connected

+

This attribute stores the LAN event connection state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

connected = lan.trigger[N].connected

+

+ + + + + + + + + + +

connected

+

The LAN event connection state:

+
  • true: Connected
  • false: Not connected

N

+

The LAN event number (1 to 8)

+
+

Details

+

This read-only attribute is set to true when the LAN trigger is connected and ready to send trigger events following a successful lan.trigger[N].connect() command; if the LAN trigger is not ready to send trigger events, this value is false.

+

This attribute is also false when either lan.trigger[N].protocol or lan.trigger[N].ipaddress attributes are changed or the remote connection closes the connection.

+

Example

+

+ + + + + + +

lan.trigger[1].protocol = lan.MULTICAST

+

print(lan.trigger[1].connected)

+

Outputs true if connected, or false if not connected.

+

Example output:

+

false

+
+

Also see

+

lan.trigger[N].connect()

+

lan.trigger[N].ipaddress

+

lan.trigger[N].protocol

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14925.htm b/WebHelpDocs/2601B-PULSE/14925.htm new file mode 100644 index 0000000..07234b7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14925.htm @@ -0,0 +1,82 @@ + + + + + lan.trigger[N].disconnect() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].disconnect()

+

This function disconnects the LAN trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

lan.trigger[N].disconnect()

+

+ + + + + + +

N

+

The LAN event number (1 to 8)

+
+

Details

+

For TCP connections, this closes the TCP connection.

+

The LAN trigger automatically disconnects when either the lan.trigger[N].protocol or lan.trigger[N].ipaddress attributes for this event are changed.

+

Also see

+

lan.trigger[N].ipaddress

+

lan.trigger[N].protocol

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14926.htm b/WebHelpDocs/2601B-PULSE/14926.htm new file mode 100644 index 0000000..a556fe2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14926.htm @@ -0,0 +1,97 @@ + + + + + lan.trigger[N].EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].EVENT_ID

+

This constant is the event identifier used to route the LAN trigger to other subsystems (using stimulus properties).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = lan.trigger[N].EVENT_ID

+

+ + + + + + + + + + +

eventID

+

Trigger event number

+

N

+

The LAN event number (1 to 8)

+
+

Details

+

Set the stimulus of any trigger event detector to the value of this constant to have it respond to incoming LAN trigger packets.

+

Example

+

+ + + + + + +

digio.trigger[14].stimulus = lan.trigger[1].EVENT_ID

+

Route occurrences of triggers on LAN trigger 1 to digital I/O trigger 14.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14927.htm b/WebHelpDocs/2601B-PULSE/14927.htm new file mode 100644 index 0000000..76042ea --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14927.htm @@ -0,0 +1,103 @@ + + + + + lan.trigger[N].ipaddress + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].ipaddress

+

This attribute specifies the address (in dotted-decimal format) of UDP or TCP listeners.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
LAN trigger N reset
Recall setup

+

Not saved

+

"0.0.0.0"

+
+

Usage

+

ipAddress = lan.trigger[N].ipaddress

+

lan.trigger[N].ipaddress = "ipAddress"

+

+ + + + + + + + + + +

ipAddress

+

The LAN address for this attribute as a string in dotted decimal notation

+

N

+

The LAN event number (1 to 8)

+
+

Details

+

Sets the IP address for outgoing trigger events.

+

Set to "0.0.0.0" for multicast.

+

After changing this setting, the lan.trigger[N].connect() command must be called before outgoing messages can be sent.

+

Example

+

+ + + + + + +

lan.trigger[3].protocol = lan.TCP

+

lan.trigger[3].ipaddress = "192.168.1.100"

+

lan.trigger[3].connect()

+

Set the protocol for LAN trigger 3 to be lan.TCP when sending LAN triggers.

+

Use IP address "192.168.1.100" to connect the LAN trigger.

+
+

Also see

+

lan.trigger[N].connect()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14928.htm b/WebHelpDocs/2601B-PULSE/14928.htm new file mode 100644 index 0000000..65c68ac --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14928.htm @@ -0,0 +1,199 @@ + + + + + lan.trigger[N].mode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].mode

+

This attribute sets the trigger operation and detection mode of the specified LAN event.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
LAN trigger N reset
Recall setup

+

Not saved

+

0 (lan.TRIG_EITHER)

+
+

Usage

+

mode = lan.trigger[N].mode

+

lan.trigger[N].mode = mode

+

+ + + + + + + + + + +

mode

+

A number representing the trigger mode (0 to 7); see the Details section for more information

+

N

+

A number representing the LAN event number (1 to 8)

+
+

Details

+

This command controls how the trigger event detector and the output trigger generator operate on the given trigger. These settings are intended to provide behavior similar to the digital I/O triggers.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

LAN trigger mode values

+

Mode

+

Number

+

Trigger packets detected as input

+

LAN trigger packet generated for output with a…

+

lan.TRIG_EITHER

+

0

+

Rising or falling edge (positive or negative state)

+

negative state

+

lan.TRIG_FALLING

+

1

+

Falling edge (negative state)

+

negative state

+

lan.TRIG_RISING

+

2

+

Rising edge (positive state)

+

positive state

+

lan.TRIG_RISINGA

+

3

+

Rising edge (positive state)

+

positive state

+

lan.TRIG_RISINGM

+

4

+

Rising edge (positive state)

+

positive state

+

lan.TRIG_SYNCHRONOUS

+

5

+

Falling edge (negative state)

+

positive state

+

lan.TRIG_SYNCHRONOUSA

+

6

+

Falling edge (negative state)

+

positive state

+

lan.TRIG_SYNCHRONOUSM

+

7

+

Rising edge (positive state)

+

negative state

+
+

lan.TRIG_RISING and lan.TRIG_RISINGA are the same.

+

lan.TRIG_RISING and lan.TRIG_RISINGM are the same.

+

Use of either lan.TRIG_SYNCHRONOUSA or lan.TRIG_SYNCHRONOUSM over lan.TRIG_SYNCHRONOUS is preferred, as lan.TRIG_SYNCHRONOUS is provided for compatibility with older firmware.

+

Example

+

+ + + + + + +

print(lan.trigger[1].mode)

+

Outputs the present LAN trigger mode of LAN event 1.

+
+

Also see

+

Digital I/O

+

TSP-Link system expansion interface

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14929.htm b/WebHelpDocs/2601B-PULSE/14929.htm new file mode 100644 index 0000000..dedf83a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14929.htm @@ -0,0 +1,104 @@ + + + + + lan.trigger[N].overrun + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].overrun

+

This attribute contains the overrun status of the LAN event detector.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

LAN trigger N clear
LAN trigger N reset
Instrument reset
Recall setup

+

Not applicable

+

Not applicable

+
+

Usage

+

overrun = lan.trigger[N].overrun

+

+ + + + + + + + + + +

overrun

+

The trigger overrun state for the specified LAN packet (true or false)

+

N

+

The LAN event number (1 to 8)

+
+

Details

+

This command indicates whether an event has been ignored because the event detector was already in the detected state when the event occurred.

+

This is an indication of the state of the event detector built into the synchronization line itself. It does not indicate if an overrun occurred in any other part of the trigger model, or in any other construct that is monitoring the event.

+

It also is not an indication of an output trigger overrun. Output trigger overrun indications are provided in the status model.

+

Example

+

+ + + + + + +

overrun = lan.trigger[5].overrun

+

print(overrun)

+

Checks the overrun status of a trigger on LAN5 and outputs the value, such as:

+

false

+
+

Also see

+

lan.trigger[N].assert()

+

lan.trigger[N].clear()

+

lan.trigger[N].stimulus

+

lan.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14930.htm b/WebHelpDocs/2601B-PULSE/14930.htm new file mode 100644 index 0000000..9994476 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14930.htm @@ -0,0 +1,100 @@ + + + + + lan.trigger[N].protocol + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].protocol

+

This attribute sets the LAN protocol to use for sending trigger messages.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
LAN trigger N reset
Recall setup

+

Not saved

+

0 (lan.TCP)

+
+

Usage

+

protocol = lan.trigger[N].protocol

+

lan.trigger[N].protocol = protocol

+

+ + + + + + + + + + +

protocol

+

The protocol to use for messages from the trigger:

+
  • 0 or lan.TCP
  • 1 or lan.UDP
  • 2 or lan.MULTICAST

N

+

The LAN event number (1 to 8)

+
+

Details

+

The LAN trigger listens for trigger messages on all supported protocols, but uses the designated protocol for sending outgoing messages. After changing this setting, lan.trigger[N].connect() must be called before outgoing event messages can be sent.

+

When the lan.MULTICAST protocol is selected, the lan.trigger[N].ipaddress attribute is ignored and event messages are sent to the multicast address 224.0.23.159.

+

Example

+

+ + + + + + +

print(lan.trigger[1].protocol)

+

Get LAN protocol to use for sending trigger messages for LAN event 1.

+
+

Also see

+

lan.trigger[N].connect()

+

lan.trigger[N].ipaddress

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14931.htm b/WebHelpDocs/2601B-PULSE/14931.htm new file mode 100644 index 0000000..239ffd8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14931.htm @@ -0,0 +1,99 @@ + + + + + lan.trigger[N].pseudostate + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].pseudostate

+

This attribute sets the simulated line state for the LAN trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
LAN trigger N reset
Recall setup

+

Not saved

+

1

+
+

Usage

+

pseudostate = lan.trigger[N].pseudostate

+

lan.trigger[N].pseudostate = pseudostate

+

+ + + + + + + + + + +

pseudostate

+

The simulated line state (0 or 1)

+

N

+

A number representing the LAN event number (1 to 8)

+
+

Details

+

This attribute can be set to initialize the pseudo line state to a known value.

+

Setting this attribute does not cause the LAN trigger to generate any events or output packets.

+

Example

+

+ + + + + + +

print(lan.trigger[1].pseudostate)

+

Get the present simulated line state for the LAN event 1.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/14933.htm b/WebHelpDocs/2601B-PULSE/14933.htm new file mode 100644 index 0000000..70e7f00 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/14933.htm @@ -0,0 +1,107 @@ + + + + + lan.trigger[N].wait() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].wait()

+

This function waits for an input trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

triggered = lan.trigger[N].wait(timeout)

+

+ + + + + + + + + + + + + + +

triggered

+

Trigger detection indication (true or false)

+

N

+

The trigger packet over LAN to wait for (1 to 8)

+

timeout

+

Maximum amount of time in seconds to wait for the trigger event

+
+

Details

+

If one or more trigger events have been detected since the last time lan.trigger[N].wait() or lan.trigger[N].clear() was called, this function returns immediately.

+

After waiting for a LAN trigger event with this function, the event detector is automatically reset and rearmed regardless of the number of events detected.

+

Example

+

+ + + + + + +

triggered = lan.trigger[5].wait(3)

+

Wait for a trigger with LAN packet 5 with a timeout of 3 seconds.

+
+

Also see

+

lan.trigger[N].assert()

+

lan.trigger[N].clear()

+

lan.trigger[N].overrun

+

lan.trigger[N].stimulus

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15007.htm b/WebHelpDocs/2601B-PULSE/15007.htm new file mode 100644 index 0000000..a0fd333 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15007.htm @@ -0,0 +1,83 @@ + + + + + localnode.autolinefreq + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.autolinefreq

+

This attribute enables or disables automatic power line frequency detection at start-up.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

true (enabled)

+
+

Usage

+

flag = localnode.autolinefreq

+

localnode.autolinefreq = flag

+

+ + + + + + +

flag

+

The auto line frequency detection setting:

+
  • true: Enable automatic line frequency detection at start-up
  • false: Disable automatic line frequency detection at start-up
+

Details

+

When this attribute is set to true, the power line frequency is detected automatically the next time the 2601B-PULSE powers up. After the power line frequency is automatically detected at power-up, the localnode.linefreq attribute is set automatically to 50 or 60.

+

If the localnode.linefreq attribute is explicitly set, localnode.autolinefreq is automatically set to false.

+

When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].autolinefreq.

+

Also see

+

localnode.linefreq

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15008.htm b/WebHelpDocs/2601B-PULSE/15008.htm new file mode 100644 index 0000000..189dfa6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15008.htm @@ -0,0 +1,95 @@ + + + + + localnode.description + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.description

+

This attribute stores a user-defined description and mDNS service name of the instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

Instrument specific (see Details)

+
+

Usage

+

localnode.description = "description"

+

description = localnode.description

+

+ + + + + + +

description

+

User-defined description and mDNS service name of the instrument; use a string of 63 characters or less

+
+

Details

+

This attribute stores a string that contains a description of the instrument. This value appears on LXI welcome page of the instrument. The value of this attribute is also used as the mDNS service name of the instrument.

+

This attribute's factory default value is "Keithley Instruments SMU <model number> - <serial number>", where <model number> and <serial number> are replaced with the actual model number and serial number of the instrument. Setting this attribute to an empty string (in other words, setting this attribute to a string of length zero, or one consisting entirely of whitespace characters) will revert the description to the factory default value.

+

When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].description.

+

Example

+

+ + + + + + +

description = "System in Lab 05"

+

localnode.description = description

+

Set description to "System in Lab 05".

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15010.htm b/WebHelpDocs/2601B-PULSE/15010.htm new file mode 100644 index 0000000..50d075a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15010.htm @@ -0,0 +1,107 @@ + + + + + node[N].getglobal() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

node[N].getglobal()

+

This function returns the value of a global variable.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

value = node[N].getglobal("name")

+

+ + + + + + + + + + + + + + +

value

+

The value of the variable

+

N

+

The node number of this instrument (1 to 64)

+

name

+

The global variable name

+
+

Details

+

This function retrieves the value of a global variable from the runtime environment of this node.

+

Do not use this command to retrieve the value of a global variable from the local node. Instead, access the global variable directly. This command should only be used from a remote master when controlling this instrument over a TSP-Link network.

+

Example

+

+ + + + + + + + +

print(node[5].getglobal("test_val"))

+

Retrieves and outputs the value of the global variable named test_val from node 5.

+
+

Also see

+

node[N].setglobal()

+

TSP advanced features

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15011.htm b/WebHelpDocs/2601B-PULSE/15011.htm new file mode 100644 index 0000000..a79b0c9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15011.htm @@ -0,0 +1,92 @@ + + + + + gettimezone() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

gettimezone()

+

This function retrieves the local time zone.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

timeZone = gettimezone()

+

+ + + + + + +

timeZone

+

The local time zone of the instrument

+
+

Details

+

See settimezone() for additional details about the time zone format and a description of the fields.

+

timeZone can be in either of the following formats:

+
  • If one parameter was used with settimezone(), the format used is:
    GMThh:mm:ss
  • If four parameters were used with settimezone(), the format used is:
    GMThh:mm:ssGMThh:mm:ss,Mmm.w.dw/hh:mm:ss,Mmm.w.dw/hh:mm:ss

Example

+

+ + + + + + +

timezone = gettimezone()

+

Reads the value of the local time zone.

+
+

Also see

+

settimezone()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15012.htm b/WebHelpDocs/2601B-PULSE/15012.htm new file mode 100644 index 0000000..879c0fe --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15012.htm @@ -0,0 +1,104 @@ + + + + + localnode.linefreq + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.linefreq

+

This attribute contains the power line frequency setting that is used for NPLC calculations.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

60 (60 Hz)

+
+

Usage

+

frequency = localnode.linefreq

+

localnode.linefreq = frequency

+

+ + + + + + +

frequency

+

An integer representing the detected or specified line frequency of the instrument

+
+

Details

+

To achieve optimum noise rejection when performing measurements at integer NPLC apertures, set the line frequency attribute to match the frequency (50 Hz or 60 Hz) of the AC power line.

+

When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].linefreq. When this attribute is set, the localnode.autolinefreq attribute is automatically set to false. You can have the instrument automatically detect the AC power line frequency and set this attribute with the line frequency detected when the instrument power is turned on by setting the localnode.autolinefreq attribute to true.

+

Example 1

+

+ + + + + + +

frequency = localnode.linefreq

+

Reads line frequency setting.

+
+

Example 2

+

+ + + + + + +

localnode.linefreq = 60

+

Sets the line frequency to 60 Hz.

+
+

Also see

+

localnode.autolinefreq

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15014.htm b/WebHelpDocs/2601B-PULSE/15014.htm new file mode 100644 index 0000000..d8b12c6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15014.htm @@ -0,0 +1,96 @@ + + + + + localnode.password + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.password

+

This attribute stores the remote access password.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (W)

+

Yes

+

LAN reset
LAN restore defaults

+

Nonvolatile memory

+

""

+
+

Usage

+

localnode.password = "password"

+

+ + + + + + +

password

+

A string that contains the remote interface password

+
+

Details

+

This write-only attribute stores the password that is set for any remote interface. When password usage is enabled (localnode.passwordmode), you must supply a password to change the configuration or to control an instrument from a web page or other remote command interface.

+

The instrument continues to use the old password for all interactions until the command to change it executes. When changing the password, give the instrument time to execute the command before attempting to use the new password.

+

You cannot retrieve a lost password from any command interface.

+

You can reset the password by resetting the LAN from the front panel or by using the lan.reset() command.

+

When using this command from a remote node, localnode should be replaced with the node reference, for example, node[5].password.

+

Example

+

+ + + + + + +

localnode.password = "N3wpa55w0rd"

+

Changes the remote interface password to N3wpa55w0rd.

+
+

Also see

+

lan.reset()

+

localnode.passwordmode

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15015.htm b/WebHelpDocs/2601B-PULSE/15015.htm new file mode 100644 index 0000000..76558e8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15015.htm @@ -0,0 +1,98 @@ + + + + + localnode.passwordmode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.passwordmode

+

This attribute stores the remote access password enable mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

1 (localnode.PASSWORD_WEB)

+
+

Usage

+

mode = localnode.passwordmode

+

localnode.passwordmode = mode

+

+ + + + + + +

mode

+

The remote password enable mode

+
+

Details

+

This attribute controls if and where remote access passwords are required. Set this attribute to one of the values below to enable password checking:

+
  • localnode.PASSWORD_NONE or 0: Disable passwords everywhere
  • localnode.PASSWORD_WEB or 1: Use passwords on the web interface only
  • localnode.PASSWORD_LAN or 2: Use passwords on the web interface and all LAN interfaces
  • localnode.PASSWORD_ALL or 3: Use passwords on the web interface and all remote command interfaces

When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].passwordmode.

+

You must also set a password.

+

Example

+

+ + + + + + +

mode = localnode.PASSWORD_WEB

+

localnode.passwordmode = mode

+

localnode.password = "SMU1234"

+

Sets value of mode to PASSWORD_WEB.

+

Allows use of passwords on the web interface only.

+

Set the password to SMU1234.

+
+

Also see

+

localnode.password

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15016.htm b/WebHelpDocs/2601B-PULSE/15016.htm new file mode 100644 index 0000000..57401e5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15016.htm @@ -0,0 +1,97 @@ + + + + + localnode.prompts + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.prompts

+

This attribute determines if the instrument generates prompts in response to command messages.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Power cycle

+

Not saved

+

0 (disabled)

+
+

Usage

+

prompting = localnode.prompts

+

localnode.prompts = prompting

+

+ + + + + + +

prompting

+

Prompting mode:

+
  • Do not generate prompts: 1
  • Generate prompts: 0
+

Details

+

When the prompting mode is enabled, the instrument generates prompts when the instrument is ready to take another command. Because the prompt is not generated until the previous command completes, enabling prompts provides handshaking with the instrument to prevent buffer overruns.

+

When prompting is enabled, the instrument might generate the following prompts:

+
  • TSP>. The standard prompt, which indicates that the previous command completed normally.
  • TSP?. The prompt that is issued if there are unread entries in the error queue when the prompt is issued. Like the TSP> prompt, it indicates that processing of the command is complete. It does not mean the previous command generated an error, only that there were still errors in the queue when the command processing was complete.
  • >>>>. The continuation prompt, which occurs when downloading scripts. When downloading scripts, many command messages must be sent as a group. The continuation prompt indicates that the instrument is expecting more messages as part of the present command.

Commands do not generate prompts. The instrument generates prompts in response to command completion.

+

Prompts are enabled or disabled only for the remote interface that is active when you send the command. For example, if you enable prompts when the LAN connection is active, they will not be enabled for a subsequent USB connection.

+

VARIABLE - NOTE
Do not disable prompting when using Test Script Builder. Test Script Builder requires prompts and sets the prompting mode automatically. If you disable prompting, the instrument will stop responding when you communicate using Test Script Builder because it is waiting for a common complete prompt from Test Script Builder.

+

Example

+

+ + + + + + +

localnode.prompts = 1

+

Enable prompting.

+
+

Also see

+

localnode.showerrors

+

tsplink.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15017.htm b/WebHelpDocs/2601B-PULSE/15017.htm new file mode 100644 index 0000000..b826572 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15017.htm @@ -0,0 +1,93 @@ + + + + + localnode.prompts4882 + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.prompts4882

+

This attribute enables and disables the generation of prompts for IEEE Std 488.2 common commands.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Power cycle

+

Not saved

+

1 (enabled)

+
+

Usage

+

prompting = localnode.prompts4882

+

localnode.prompts4882 = prompting

+

+ + + + + + +

prompting

+

IEEE Std 488.2 prompting mode:

+
  • Disable prompting: 0
  • Enable prompting: 1
+

Details

+

When this attribute is enabled, the IEEE Std 488.2 common commands generate prompts if prompting is enabled with the localnode.prompts attribute. If localnode.prompts4882 is enabled, limit the number of *trg commands sent to a running script to 50 regardless of the setting of the localnode.prompts attribute.

+

When this attribute is disabled, IEEE Std 488.2 common commands will not generate prompts. When using the *trg command with a script that executes trigger.wait() repeatedly, disable prompting to avoid problems associated with the command interface input queue filling.

+

Example

+

+ + + + + + +

localnode.prompts4882 = 0

+

Disables IEEE Std 488.2 common command prompting.

+
+

Also see

+

localnode.prompts

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15018.htm b/WebHelpDocs/2601B-PULSE/15018.htm new file mode 100644 index 0000000..4309688 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15018.htm @@ -0,0 +1,96 @@ + + + + + localnode.revision + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.revision

+

This attribute stores the firmware revision level.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

revision = localnode.revision

+

+ + + + + + +

revision

+

Firmware revision level

+
+

Details

+

This attribute indicates the revision number of the firmware that is presently running in the instrument.

+

When using this command from a remote node, localnode should be replaced with the node reference. For example, node[5].revision.

+

Example

+

+ + + + + + +

print(localnode.revision)

+

Outputs the present revision level.

+

Sample output:

+

1.0.0

+
+

Also see

+

localnode.description

+

localnode.model

+

localnode.serialno

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15019.htm b/WebHelpDocs/2601B-PULSE/15019.htm new file mode 100644 index 0000000..a000323 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15019.htm @@ -0,0 +1,95 @@ + + + + + localnode.serialno + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.serialno

+

This attribute stores the instrument's serial number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

serialno = localnode.serialno

+

+ + + + + + +

serialno

+

The serial number of the instrument

+
+

Details

+

This indicates the instrument serial number.

+

Example

+

+ + + + + + +

display.clear()

+

display.settext(localnode.serialno)

+

Clears the instrument display.

+

Places the serial number of the instrument on the top line of its display.

+
+

Also see

+

localnode.description

+

localnode.model

+

localnode.revision

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15020.htm b/WebHelpDocs/2601B-PULSE/15020.htm new file mode 100644 index 0000000..c8264c7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15020.htm @@ -0,0 +1,105 @@ + + + + + node[N].setglobal() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

node[N].setglobal()

+

This function sets the value of a global variable.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

node[N].setglobal("name", value)

+

+ + + + + + + + + + + + + + +

N

+

The node number of this instrument (1 to 6463)

+

name

+

The global variable name to set

+

value

+

The value to assign to the variable

+
+

Details

+

From a remote node, use this function to assign the given value to a global variable.

+

Do not use this command to create or set the value of a global variable from the local node (set the global variable directly instead). This command should only be used from a remote master when controlling this instrument over a TSP-Link network.

+

Example

+

+ + + + + + +

node[3].setglobal("x", 5)

+

Sets the global variable x on node 3 to the value of 5.

+
+

Also see

+

node[N].getglobal()

+

TSP advanced features

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15021.htm b/WebHelpDocs/2601B-PULSE/15021.htm new file mode 100644 index 0000000..04a0ff5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15021.htm @@ -0,0 +1,122 @@ + + + + + settimezone() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

settimezone()

+

This function sets the local time zone.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

settimezone(offset)

+

settimezone("offset", "dstOffset", "dstStart", "dstEnd")

+

+ + + + + + + + + + + + + + + + + + +

offset

+

String representing offset from UTC

+

dstOffset

+

String representing the daylight savings offset from UTC

+

dstStart

+

String representing when daylight savings time starts

+

dstEnd

+

String representing when daylight savings time ends

+
+

Details

+

You only need to set the time zone if you use the os.time() and os.date() functions.

+

If only one parameter is given, the same time offset is used throughout the year. If four parameters are given, time is adjusted twice during the year for daylight savings time.

+

offset and dstOffset are strings of the form "[+|-]hh[:mm[:ss]]" that indicate how much time must be added to the local time to get UTC time:

+
  • hh is a number between 0 and 23 that represents hours
  • mm is a number between 0 and 59 that represents minutes
  • ss is a number between 0 and 59 that represents seconds

The minute, second, +, and - fields are optional.

+

For example, to set the UTC-5 time zone, you specify the string "5", because UTC-5 is 5 hours behind UTC and you must add 5 hours to the local time to determine UTC time. To specify the time zone UTC4, you specify "-4", because UTC4 is 4 hours ahead of UTC and 4 hours must be subtracted from the local time to determine UTC.

+

dstStart and dstEnd are strings of the form "MM.w.dw/hh[:mm[:ss]]" that indicate when daylight savings time begins and ends respectively:

+
  • MM is a number between 1 and 12 that represents the month
  • w is a number between 1 and 5 that represents the week in the month
  • dw is a number between 0 and 6 that represents the day of the week (where 0 is Sunday)

The rest of the fields represent the time of day that the change takes effect:

+
  • hh represents hours
  • mm represents minutes
  • ss represents seconds

The minutes and seconds fields are optional.

+

The week of the month and day of the week fields are not specific dates.

+

Example

+

+ + + + + + +

settimezone("8", "1", "3.3.0/02", "11.2.0/02")

+

settimezone(offset)

+

Sets offset to equal +8 hours, +1 hour for DST, starts on Mar 14 at 2:00 am, ends on Nov 7 at 2:00 am.

+

Sets local time zone to offset.

+
+

Also see

+

gettimezone()

+

os.time()

+

settime()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15022.htm b/WebHelpDocs/2601B-PULSE/15022.htm new file mode 100644 index 0000000..91af27f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15022.htm @@ -0,0 +1,94 @@ + + + + + localnode.showerrors + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.showerrors

+

This attribute sets whether or not the instrument automatically sends generated errors.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Power cycle

+

Not saved

+

0 (disabled)

+
+

Usage

+

errorMode = localnode.showerrors

+

localnode.showerrors = errorMode

+

+ + + + + + +

errorMode

+

Show error setting:

+
  • Show errors: 1
  • Do not show errors: 0
+

Details

+

If this attribute is set to 1, the instrument automatically sends any generated errors stored in the error queue, and then clears the queue. Errors are processed after executing a command message (just before issuing a prompt, if prompts are enabled).

+

If this attribute is set to 0, errors are left in the error queue and must be explicitly read or cleared.

+

When using this command from a remote node, localnode should be replaced with the node reference, for example, node[5].showerrors.

+

Example

+

+ + + + + + +

localnode.showerrors = 1

+

Enables sending of generated errors.

+
+

Also see

+

localnode.prompts

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15041.htm b/WebHelpDocs/2601B-PULSE/15041.htm new file mode 100644 index 0000000..5373171 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15041.htm @@ -0,0 +1,108 @@ + + + + + makegetter() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

makegetter()

+

This function creates a function to get the value of an attribute.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

getter = makegetter(table, "attributeName")

+

+ + + + + + + + + + + + + + +

getter

+

The return value

+

table

+

Read-only table where the attribute is located

+

attributeName

+

A string representing the name of the attribute

+
+

Details

+

This function is useful for aliasing attributes to improve execution speed. Calling the function created with makegetter() executes more quickly than accessing the attribute directly.

+

Creating a getter function is only useful if it is going to be called several times. Otherwise, the overhead of creating the getter function outweighs the overhead of accessing the attribute directly.

+

Example

+

+ + + + + + + + +

getlevel = makegetter(smua.source, "levelv")

+

v = getlevel()

+

Creates a getter function called getlevel.

+

When getlevel() is called, it returns the value of smua.source.levelv.

+
+

Also see

+

makesetter()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15042.htm b/WebHelpDocs/2601B-PULSE/15042.htm new file mode 100644 index 0000000..c6663e7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15042.htm @@ -0,0 +1,109 @@ + + + + + makesetter() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

makesetter()

+

This function creates a function that, when called, sets the value of an attribute.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

setter = makesetter(table, "attributeName")

+

+ + + + + + + + + + + + + + +

setter

+

Function that sets the value of the attribute

+

table

+

Read-only table where the attribute is located

+

attributeName

+

The string name of the attribute

+
+

Details

+

This function is useful for aliasing attributes to improve execution speed. Calling the setter function execute more quickly than accessing the attribute directly.

+

Creating a setter function is only useful if it is going to be called several times. If you are not calling the setter function several times, it is more efficient to access the attribute directly.

+

Example

+

+ + + + + + + + +

setlevel = makesetter(smua.source, "levelv")for v = 1, 10 do

+

setlevel(v)

+

end

+

Creates a setter function called setlevel.

+

Using setlevel() in the loop sets the value of smua.source.levelv, performing a source sweep.

+
+

Also see

+

makegetter()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15050.htm b/WebHelpDocs/2601B-PULSE/15050.htm new file mode 100644 index 0000000..a6b7bb9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15050.htm @@ -0,0 +1,100 @@ + + + + + meminfo() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

meminfo()

+

This function returns the present amount of available memory and the total amount of memory in the instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

freeMem, totalMem = meminfo()

+

+ + + + + + + + + + +

freeMem

+

The amount of free dynamically allocated memory available

+

totalMem

+

The total amount of dynamically allocated memory in the instrument

+
+

Details

+

This function returns two values:

+
  • The amount of free dynamically allocated memory available in kilobytes
  • The total amount of dynamically allocated memory on the instrument in kilobytes

The difference between the two values is the amount presently used.

+

Example

+

+ + + + + + +

print(meminfo())

+

Retrieve the amount of free and total memory in the instrument.

+

Output:

+

2.89840e+04 3.27680e+04

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15054.htm b/WebHelpDocs/2601B-PULSE/15054.htm new file mode 100644 index 0000000..0d8b237 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15054.htm @@ -0,0 +1,86 @@ + + + + + opc() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

opc()

+

This function sets the operation complete status bit when all overlapped commands are completed.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

opc()

+

Details

+

This function causes the operation complete bit in the Standard Event Status Register to be set when all previously started local overlapped commands are complete.

+

Note that each node independently sets its operation complete bits in its own status model. Any nodes that are not actively performing overlapped commands set their bits immediately. All remaining nodes set their own bits as they complete their own overlapped commands.

+

Example

+

+ + + + + + +

opc()

+

waitcomplete()

+

print("1")

+

Output:

+

1

+
+

Also see

+

Status model

+

waitcomplete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15058.htm b/WebHelpDocs/2601B-PULSE/15058.htm new file mode 100644 index 0000000..d6fbfaa --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15058.htm @@ -0,0 +1,126 @@ + + + + + printnumber() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

printnumber()

+

This function prints numbers using the configured format.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

printnumber(value1)

+

printnumber(value1, value2)

+

printnumber(value1, ..., valueN)

+

+ + + + + + + + + + + + + + + + + + +

value1

+

First value to print in the configured format

+

value2

+

Second value to print in the configured format

+

valueN

+

Last value to print in the configured format

+

...

+

One or more values separated with commas

+
+

Details

+

There are multiple ways to use this function, depending on how many numbers are to be printed.

+

This function prints the given numbers using the data format specified by format.data and format.asciiprecision.

+

Example

+

+ + + + + + +

format.asciiprecision = 10

+

x = 2.54

+

printnumber(x)

+

format.asciiprecision = 3

+

printnumber(x, 2.54321, 3.1)

+

Configure the ASCII precision to 10 and set x to 2.54.

+

Read the value of x based on these settings.

+

Change the ASCII precision to 3.

+

View how the change affects the output of x and some numbers.

+

Output:

+

2.540000000e+00

+

2.54e+00, 2.54e+00, 3.10e+00

+
+

Also see

+

format.asciiprecision

+

format.byteorder

+

format.data

+

print()

+

printbuffer()printbuffer()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15061.htm b/WebHelpDocs/2601B-PULSE/15061.htm new file mode 100644 index 0000000..08d13ee --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15061.htm @@ -0,0 +1,53 @@ + + + + + Reset + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Reset

+

Resets settings to their default settings.

+

digio.trigger[N].reset()

+

lan.reset()

+

localnode.reset()

+

reset()

+

smua.reset()

+

timer.reset()

+

trigger.blender[N].reset()

+

trigger.timer[N].reset()

+

tsplink.trigger[N].reset()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15062.htm b/WebHelpDocs/2601B-PULSE/15062.htm new file mode 100644 index 0000000..e4ebd29 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15062.htm @@ -0,0 +1,63 @@ + + + + + Scripting + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Scripting

+

Scripting helps you combine commands into a block of code that the instrument can run. Scripts help you communicate with the instrument efficiently. These commands describe how to create, load, modify, run, and exit scripts.

+

For detail on using scripts, see Fundamentals of scripting for TSP.

+

exit()

+

makegetter()

+

makesetter()

+

script.anonymous

+

script.delete()

+

script.factory.catalog()

+

script.load()

+

script.new()

+

script.newautorun()

+

script.restore()

+

script.run()

+

script.user.catalog()

+

scriptVar.autorun

+

scriptVar.list()

+

scriptVar.name

+

scriptVar.run()

+

scriptVar.save()

+

scriptVar.source

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15063.htm b/WebHelpDocs/2601B-PULSE/15063.htm new file mode 100644 index 0000000..2283ef8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15063.htm @@ -0,0 +1,106 @@ + + + + + script.load() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.load()

+

This function creates a script from a specified file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

scriptVar = script.load("file")

+

scriptVar = script.load("file", "name")

+

+ + + + + + + + + + + + + + +

scriptVar

+

The created script; this is nil if an error is encountered

+

file

+

The path and file name of the script file to load

+

name

+

The name of the script to be created

+
+

Details

+

The file path may be absolute or relative to the current working directory. The root folder of the USB flash drive has the absolute path "/usb1/". Both the forward slash (/) and backslash (\) are supported as directory separators.

+

The file to be loaded must start with the loadscript or loadandrunscript keywords, contain the body of the script, and end with the endscript keyword.

+

Script naming:

+
  • If the name parameter is an empty string, or name is absent (or nil) and the script name cannot be extracted from the file, scriptVar is the only handle to the created script.
  • If name is given (and not nil), any script name embedded in the file is ignored.
  • If name conflicts with the name of an existing script in the script.user.scripts table, the existing script’s name attribute is set to an empty string before it is replaced in the script.user.scripts table by the new script.
  • If name is absent or nil, the command attempts to extract the name of the script from the file. Any conflict between the extracted name and that of an existing script in the scripts table generates an error. If the script name cannot be extracted, the created script's name attribute is initialized to the empty string and must be set to a valid nonempty string before saving the script to nonvolatile memory.

Example

+

+ + + + + + +

myTest8 =
script.load("/usb1/filename.tsp", "myTest8")

+

Loads the script myTest8 from the USB flash drive.

+
+

Also see

+

script.new()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15064.htm b/WebHelpDocs/2601B-PULSE/15064.htm new file mode 100644 index 0000000..46ffcef --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15064.htm @@ -0,0 +1,129 @@ + + + + + script.new() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.new()

+

This function creates a script.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

scriptVar = script.new("code")

+

scriptVar = script.new("code", "name")

+

+ + + + + + + + + + + + + + +

scriptVar

+

The name of the variable that will reference the script

+

code

+

A string containing the body of the script

+

name

+

The name of the script

+
+

Details

+

The name parameter is the name that is added to the script.user.scripts table. If name is not given, an empty string is used, and the script is unnamed. If the name already exists in script.user.scripts, the existing script's name attribute is set to an empty string before it is replaced by the new script.

+

Note that name is the value that is used for the instrument front panel display. If this value is not defined, the script is not available from the front panel.

+

You must save the new script into nonvolatile memory to keep it when the instrument is turned off.

+

Example 1

+

+ + + + + + + + +

myTest8 = script.new(

+

"display.clear() display.settext('Hello from myTest8')", "myTest8")

+

myTest8()

+

Creates a new script referenced by the variable myTest8 with the name "myTest8".

+

Runs the script. The instrument displays "Hello from myTest8".

+
+

Example 2

+

+ + + + + + + + +

autoexec = script.new(

+

"display.clear() display.settext('Hello from autoexec')", 'autoexec')

+

Creates a new autoexec script that clears the display when the instrument is turned on and displays "Hello from autoexec".

+
+

Also see

+

Create a script using the script.new() command

+

Global variables and the script.user.scripts table

+

Named scripts

+

scriptVar.save()

+

script.newautorun()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15067.htm b/WebHelpDocs/2601B-PULSE/15067.htm new file mode 100644 index 0000000..fcac5e4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15067.htm @@ -0,0 +1,49 @@ + + + + + RS-232 + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

RS-232

+

serial.baud

+

serial.databits

+

serial.flowcontrol

+

serial.parity

+

serial.read()

+

serial.write()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15068.htm b/WebHelpDocs/2601B-PULSE/15068.htm new file mode 100644 index 0000000..6fb0a7a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15068.htm @@ -0,0 +1,97 @@ + + + + + serial.baud + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

serial.baud

+

This attribute configures the baud rate for the RS-232 port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

9600

+
+

Usage

+

baud = serial.baud

+

serial.baud = baud

+

+ + + + + + +

baud

+

The baud rate (300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, or 115200)

+
+

Details

+

A new baud rate setting takes effect when the command to change it is processed.

+

VARIABLE - NOTE
Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set the baud rate from one of the other command interfaces or from the front panel.

+

The reset function has no effect on data bits.

+

Example

+

+ + + + + + +

serial.baud = 1200

+

Sets the baud rate to 1200.

+
+

Also see

+

RS-232 interface operation

+

serial.databits

+

serial.flowcontrol

+

serial.parity

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15069.htm b/WebHelpDocs/2601B-PULSE/15069.htm new file mode 100644 index 0000000..412474a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15069.htm @@ -0,0 +1,97 @@ + + + + + serial.databits + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

serial.databits

+

This attribute configures character width (data bits) for the RS-232 port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

8

+
+

Usage

+

bits = serial.databits

+

serial.databits = bits

+

+ + + + + + +

bits

+

An integer representing the character width (7 or 8)

+
+

Details

+

A new data width setting takes effect when the command to change it is processed.

+

VARIABLE - NOTE
Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set the character width from one of the other command interfaces or from the front panel.

+

The reset function has no effect on data bits.

+

Example

+

+ + + + + + +

serial.databits = 8

+

Sets data width to 8.

+
+

Also see

+

RS-232 interface operation

+

serial.baud

+

serial.flowcontrol

+

serial.parity

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15070.htm b/WebHelpDocs/2601B-PULSE/15070.htm new file mode 100644 index 0000000..d145f40 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15070.htm @@ -0,0 +1,96 @@ + + + + + serial.flowcontrol + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

serial.flowcontrol

+

This attribute configures flow control for the RS-232 port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

"none" (serial.FLOW_NONE)

+
+

Usage

+

flow = serial.flowcontrol

+

serial.flowcontrol = flow

+

+ + + + + + +

flow

+

A string or value that represents flow control configuration; set to:

+
  • "none" or serial.FLOW_NONE (selects no flow control)
  • "hardware" or serial.FLOW_HARDWARE (selects hardware flow control)
+

Details

+

A new flow control setting takes effect when the command to change it is processed.

+

VARIABLE - NOTE
Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set the flow control from one of the other command interfaces or from the front panel.

+

The reset function has no effect on flow control.

+

Example

+

+ + + + + + +

serial.flowcontrol = serial.FLOW_NONE

+

Sets flow control to none.

+
+

Also see

+

serial.baud

+

serial.databits

+

serial.parity

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15071.htm b/WebHelpDocs/2601B-PULSE/15071.htm new file mode 100644 index 0000000..b34db57 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15071.htm @@ -0,0 +1,97 @@ + + + + + serial.parity + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

serial.parity

+

This attribute configures parity for the RS-232 port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

"none" (serial.PARITY_NONE)

+
+

Usage

+

parity = serial.parity

+

serial.parity = parity

+

+ + + + + + +

parity

+

Set parity to one of the following values:

+
  • Select no parity ("none" or serial.PARITY_NONE)
  • Select even parity ("even" or serial.PARITY_EVEN)
  • Select odd parity ("odd" or serial.PARITY_ODD)
+

Details

+

A new parity setting takes effect when the command to change it is processed.

+

VARIABLE - NOTE
Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set parity from one of the other command interfaces or from the front panel.

+

The reset function has no effect on parity.

+

Example

+

+ + + + + + +

serial.parity = serial.PARITY_NONE

+

Sets parity to none.

+
+

Also see

+

RS-232 interface operation

+

serial.baud

+

serial.databits

+

serial.flowcontrol

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15072.htm b/WebHelpDocs/2601B-PULSE/15072.htm new file mode 100644 index 0000000..83f4b06 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15072.htm @@ -0,0 +1,105 @@ + + + + + serial.read() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

serial.read()

+

This function reads available characters (data) from the serial port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

data = serial.read(maxchars)

+

+ + + + + + + + + + +

data

+

A string that consists of all data read from the serial port

+

maxchars

+

An integer that specifies the maximum number of characters to read

+
+

Details

+

This function reads available characters from the serial port. It does not wait for new characters to arrive. As long as maxchars is less than 200 characters, all characters that are received by the serial port (before the serial.read() command is executed) are returned. If too many characters are received between calls to this function, the RS-232 buffers will overflow and some characters may be lost.

+

Call this function as many times as necessary to receive the required number of characters. For optimal performance, use a small delay between repeated calls to this function.

+

The data returned is the raw data stream read from the port. No characters, such as control characters or terminator characters, are interpreted.

+

If you attempt to use this function when the serial port is enabled as a command interface, a settings conflict error is generated.

+

Example

+

+ + + + + + +

data = serial.read(200)

+

 

+

print(data)

+

Read data from the serial port.

+

Output:

+

John Doe

+

The above output indicates that the string "John Doe" was read from the serial port.

+
+

Also see

+

serial.write()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15073.htm b/WebHelpDocs/2601B-PULSE/15073.htm new file mode 100644 index 0000000..1a7c7d1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15073.htm @@ -0,0 +1,92 @@ + + + + + serial.write() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

serial.write()

+

This function writes data to the serial port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

serial.write("data")

+

+ + + + + + +

data

+

A string representing the data to write

+
+

Details

+

This function writes the specified string to the serial port, where it can be read by connected equipment (for example, a component handler).

+

No terminator characters are added to the data, and data is written exactly as specified by the data parameter.

+

Example

+

+ + + + + + +

serial.write("1 2 3 4")

+

Write data string "1 2 3 4" to the serial port.

+
+

Also see

+

serial.read()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15081.htm b/WebHelpDocs/2601B-PULSE/15081.htm new file mode 100644 index 0000000..3c192e5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15081.htm @@ -0,0 +1,95 @@ + + + + + setup.poweron + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

setup.poweron

+

This attribute specifies which saved setup to recall when the instrument is turned on.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

0

+
+

Usage

+

id = setup.poweron

+

setup.poweron = id

+

+ + + + + + +

id

+

An integer that specifies the setup to recall when the instrument power is turned on (0 to 5)

+
+

Details

+

When id = 0, the instrument uses the factory default setup when it is turned on. When id is set to 1 to 5, it uses the setup saved with setup.save().

+

Only setups stored in nonvolatile memory are available (you cannot recall a script from a USB flash drive with this command).

+

To save a script that is used when the instrument is powered on, you can create a configuration script and name it autoexec.

+

Example

+

+ + + + + + +

setup.poweron = 0

+

Set the instrument to use the factory default setup when power is turned on.

+
+

Also see

+

setup.save()

+

Start-up (power-on) configuration

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15083.htm b/WebHelpDocs/2601B-PULSE/15083.htm new file mode 100644 index 0000000..09925ba --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15083.htm @@ -0,0 +1,94 @@ + + + + + setup.save() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

setup.save()

+

This function saves the present setup as a user-saved setup.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

setup.save(id)

+

+ + + + + + +

id

+

An integer or string specifying where to save the user setup:

+
  • Save in nonvolatile memory (1 to 5)
  • Save as user-saved setup on a USB flash drive ("/path/filename")
+

Details

+

When the id parameter is an integer (n), it is interpreted as the setup number to save to the instrument's nonvolatile memory.

+

VARIABLE - NOTE
When you save to a specified integer (1 to 5) in nonvolatile memory, the previous setup at that same location is overwritten.

+

When the id parameter is a string, it is interpreted as the path and file name of the location to save the present setup on a USB flash drive. The path may be absolute or relative to the current working directory.

+

Example

+

+ + + + + + +

setup.save(5)

+

Saves the present setup to the internal memory of the instrument at location 5.

+
+

Also see

+

Saved setups

+

setup.recall()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15088.htm b/WebHelpDocs/2601B-PULSE/15088.htm new file mode 100644 index 0000000..a9e4f54 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15088.htm @@ -0,0 +1,83 @@ + + + + + smua.abort() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.abort()

+

This function terminates all overlapped operations on the source-measure unit (SMU).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.abort()

+

Details

+

The smua.abort() function does not turn the output off or change any settings.

+

If this function is used to abort a sweep, when it is executed, the SMU exits its trigger model immediately and returns to the idle state of the trigger model.

+

Example

+

+ + + + + + +

smua.abort()

+

Terminates all overlapped operations.

+
+

Also see

+

smua.measure.overlappedY()

+

smua.trigger.initiate()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15089.htm b/WebHelpDocs/2601B-PULSE/15089.htm new file mode 100644 index 0000000..ccd467a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15089.htm @@ -0,0 +1,86 @@ + + + + + smua.cal.lock() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.lock()

+

This function disables the commands that change calibration settings.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.cal.lock()

+

+

Details

+

Before you can lock calibration, the calibration constants must be written to nonvolatile memory or a previous calibration set must be restored. Error code 5012, "Cal data not saved - save or restore before lock," results if this function is called when the calibration state is smua.CALSTATE_CALIBRATING.

+

Example

+

+ + + + + + +

smua.cal.lock()

+

Disables calibration functions.

+
+

Also see

+

Adjustment

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.state

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15090.htm b/WebHelpDocs/2601B-PULSE/15090.htm new file mode 100644 index 0000000..53201c3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15090.htm @@ -0,0 +1,96 @@ + + + + + smua.cal.restore() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.restore()

+

This function loads a stored set of calibration constants.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.cal.restore()

+

smua.cal.restore(calset)

+

+ + + + + + +

calset

+

The calibration set to be loaded; set calset to one of the following values:

+
  • 0 or smua.CALSET_NOMINAL: A set of calibration constants that are uncalibrated, but set to nominal values to allow rudimentary functioning of the instrument
  • 1 or smua.CALSET_FACTORY: The calibration constants when the instrument left the factory
  • 2 or smua.CALSET_DEFAULT: The normal calibration set
  • 3 or smua.CALSET_PREVIOUS: The calibration set that was used before the last default set was overwritten
+

Details

+

This function overwrites the present set of calibration constants with constants read from nonvolatile memory.

+

This function is disabled until a successful call to smua.cal.unlock() is made.

+

If calset is not specified, smua.CALSET_DEFAULT is used.

+

Example

+

+ + + + + + +

smua.cal.restore()

+

Restores factory calibration constants.

+
+

Also see

+

Adjustment

+

smua.cal.lock()

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15091.htm b/WebHelpDocs/2601B-PULSE/15091.htm new file mode 100644 index 0000000..6abdab5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15091.htm @@ -0,0 +1,90 @@ + + + + + smua.cal.save() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.save()

+

This function stores the active calibration constants to nonvolatile memory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.cal.save()

+

+

Details

+

This function stores the active set of calibration constants to nonvolatile memory. The previous calibration constants (from the default calibration set) are copied to the previous calibration set (smua.CALSET_PREVIOUS) before overwriting the default calibration set.

+

This function is disabled until a successful call to smua.cal.unlock() is made.

+

If any of the calibration constants have been changed, this function is disabled unless the calibration date, the calibration due date, and the calibration adjust date have been assigned new values.

+

Example

+

+ + + + + + +

smua.cal.save()

+

Stores calibration constants in nonvolatile memory.

+
+

Also see

+

Adjustment

+

smua.cal.adjustdate

+

smua.cal.date

+

smua.cal.due

+

smua.cal.lock()

+

smua.cal.restore()

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15092.htm b/WebHelpDocs/2601B-PULSE/15092.htm new file mode 100644 index 0000000..b15d936 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15092.htm @@ -0,0 +1,95 @@ + + + + + smua.cal.unlock() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.unlock()

+

This function enables the commands that change calibration settings.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.cal.unlock(password)

+

+ + + + + + +

password

+

Calibration password

+
+

Details

+

This function enables the calibration functions to change the calibration settings.

+

The password when the instrument is shipped from the factory is "KI0026XX".

+

Example

+

+ + + + + + +

smua.cal.unlock("KI0026XX")

+

Unlocks calibration.

+
+

Also see

+

Adjustment

+

smua.cal.lock()

+

smua.cal.password

+

smua.cal.state

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15093.htm b/WebHelpDocs/2601B-PULSE/15093.htm new file mode 100644 index 0000000..265dbb6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15093.htm @@ -0,0 +1,105 @@ + + + + + smua.cal.adjustdate + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.adjustdate

+

This attribute stores the date of the last calibration adjustment.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU cal. restore

+

SMU nonvolatile memory

+

Initially set to factory
calibration date

+
+

Usage

+

adjustDate = smua.cal.adjustdate

+

smua.cal.adjustdate = adjustDate

+

+ + + + + + +

adjustDate

+

Date of the last adjustment

+
+

Details

+

This attribute stores the adjustment date associated with the active calibration set. The adjustment date can be read at any time but can only be assigned a new value when calibration has been enabled with the smua.cal.unlock() function.

+

You cannot change the adjustment date without first making a change to the calibration constants.

+

Once you change any calibration constants, you must set the adjustment date before you can save the calibration data to the nonvolatile memory of the SMU.

+

This attribute is stored with the active calibration set. If a different calibration set is restored, this attribute reflects the date stored with that set.

+

smua.cal.adjustdate must be set to the date the adjustment was done using the UTC time and date. The date is stored as the number of seconds since UTC, 12:00 am Jan 1, 1970.

+

Due to the internal storage format, smua.cal.adjustdate is only accurate to within a few minutes of the value set.

+

Example

+

+ + + + + + +

smua.cal.adjustdate = os.time()

+

Sets the adjustment date to the current time set on the instrument.

+
+

Also see

+

Adjustment

+

os.time()

+

smua.cal.date

+

smua.cal.due

+

smua.cal.lock()

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.state

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15094.htm b/WebHelpDocs/2601B-PULSE/15094.htm new file mode 100644 index 0000000..115cf2d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15094.htm @@ -0,0 +1,103 @@ + + + + + smua.cal.date + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.date

+

This attribute stores the calibration date of the active calibration set.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU calibration restore

+

SMU nonvolatile memory

+

Initially set to factory calibration date

+
+

Usage

+

calDate = smua.cal.date

+

smua.cal.date = calDate

+

+ + + + + + +

calDate

+

The calibration date of the active calibration set

+
+

Details

+

This attribute stores the calibration date that is associated with the active calibration set. The calibration date can be read at any time but can only be assigned a new value when calibration has been enabled with the smua.cal.unlock() function. It is typically set to the date when the instrument was calibrated.

+

This attribute is stored with the active calibration set. If a different calibration set is restored, this attribute will reflect the date stored with that set.

+

smua.cal.date must be set to the date the calibration was done using the UTC time and date. The date is stored as the number of seconds since UTC 12:00 am Jan 1, 1970.

+

Due to the internal storage format, smua.cal.date is accurate to within a few minutes of the value set.

+

Example

+

+ + + + + + +

smua.cal.date = os.time()

+

Sets calibration date to the present time set on the instrument.

+
+

Also see

+

Adjustment

+

os.time()

+

smua.cal.adjustdate

+

smua.cal.due

+

smua.cal.lock()

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.state

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15095.htm b/WebHelpDocs/2601B-PULSE/15095.htm new file mode 100644 index 0000000..2c1e400 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15095.htm @@ -0,0 +1,102 @@ + + + + + smua.cal.due + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.due

+

This attribute stores the calibration due date for the next calibration.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU cal. restore

+

SMU nonvolatile memory

+

0

+
+

Usage

+

calDue = smua.cal.due

+

smua.cal.due = calDue

+

+ + + + + + +

calDue

+

Due date of next calibration (0 indicates that no date is set)

+
+

Details

+

This attribute stores the calibration due date associated with the active calibration set. The calibration due date can be read at any time but can only be assigned a new value when calibration has been enabled with the smua.cal.unlock() function. It is typically set to the date when the next calibration should be performed.

+

This attribute is stored with the active calibration set. If a different calibration set is restored, this attribute reflects the due date stored with that set.

+

smua.cal.due must be set to the date the next calibration is required using the UTC time and date. The date is stored as the number of seconds since UTC 12:00 am Jan 1, 1970.

+

Due to the internal storage format, smua.cal.due is only accurate to within a few minutes of the value set.

+

Example

+

+ + + + + + +

smua.cal.due = os.time() + 365 * 24 * 60 * 60

+

Sets the calibration due date equal to one year from the present time set on the instrument.

+
+

Also see

+

Adjustment

+

os.time()

+

smua.cal.adjustdate

+

smua.cal.date

+

smua.cal.lock()

+

smua.cal.restore()

+

smua.cal.state

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15096.htm b/WebHelpDocs/2601B-PULSE/15096.htm new file mode 100644 index 0000000..e3a9455 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15096.htm @@ -0,0 +1,93 @@ + + + + + smua.cal.password + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.password

+

This attribute stores the password required to enable calibration.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (W)

+

Yes

+

Not applicable

+

SMU nonvolatile memory

+

"KI0026XX"

+
+

Usage

+

smua.cal.password = "newPassword"

+

+ + + + + + +

newPassword

+

A string that contains the new password

+
+

Details

+

A new password can only be assigned when calibration has been unlocked.

+

The calibration password is write-only and cannot be read.

+

Example

+

+ + + + + + +

smua.cal.password = "LetMeIn"

+

Assigns a new calibration password.

+
+

Also see

+

Adjustment

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15098.htm b/WebHelpDocs/2601B-PULSE/15098.htm new file mode 100644 index 0000000..351902e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15098.htm @@ -0,0 +1,99 @@ + + + + + smua.cal.state + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.state

+

This attribute returns the present calibration state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+
+

Usage

+

calState = smua.cal.state

+

+ + + + + + +

calState

+

The present calibration state; when reading this attribute, calState has one of the following values:

+
  • 0 or smua.CALSTATE_LOCKED: Calibration is locked
  • 1 or smua.CALSTATE_CALIBRATING: The calibration constants or dates have been changed but not yet saved to nonvolatile memory
  • 2 or smua.CALSTATE_UNLOCKED: Calibration is unlocked but none of the calibration constants or dates have changed since the last save/restore
+

Details

+

This read-only attribute indicates the calibration state of the instrument: Locked, calibrating, or unlocked.

+

Example

+

+ + + + + + +

calstate = smua.cal.state

+

print(calstate)

+

Reads calibration state.

+

Output:

+

0.000000e+00

+

The above output indicates that calibration is locked.

+
+

Also see

+

Adjustment

+

smua.cal.lock()

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15099.htm b/WebHelpDocs/2601B-PULSE/15099.htm new file mode 100644 index 0000000..95e8bb6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15099.htm @@ -0,0 +1,132 @@ + + + + + smua.contact.calibratehi() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.contact.calibratehi()

+

This function adjusts the high/sense high contact check measurement.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.contact.calibratehi(cp1Measured, cp1Reference, cp2Measured, cp2Reference)

+

+ + + + + + + + + + + + + + + + + + +

cp1Measured

+

The value measured by this SMU for point 1

+

cp1Reference

+

The reference measurement for point 1 as measured externally

+

cp2Measured

+

The value measured by this SMU for point 2

+

cp2Reference

+

The reference measurement for point 2 as measured externally

+
+

Details

+

Contact check measurement calibration does not require range information.

+

Typically, points one and two will be near 0 Ω and 50 Ω, respectively.

+

All four measurements (cp1Measured, cp1Reference, cp2Measured, and cp2Reference) must be made with the calibration set that is active. If not, corruption of the calibration constants may result.

+

The new calibration constants are activated immediately but are not written to nonvolatile memory. Use smua.cal.save() to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.

+

This function is disabled until a successful call to smua.cal.unlock() is made.

+

Example

+

+ + + + + + + + +

-- Short SENSE LO and LO terminals.

+

-- Short SENSE HI and HI terminals.

+

-- Allow readings to settle, then get measurements.

+

r0_hi, r0_lo = smua.contact.r()

+

 

+

-- Connect 50 OHM resistor between SENSE LO and LO.

+

-- Connect 50 OHM resistor between SENSE HI and HI.

+

-- Allow readings to settle, then get measurements.

+

r50_hi, r50_lo = smua.contact.r()

+

smua.contact.calibratelo(r0_lo, Z_actual_lo, r50_lo, 50_ohm_actual_lo)

+

smua.contact.calibratehi(r0_hi, Z_actual_hi, r50_hi, 50_ohm_actual_hi)

+

The instrument performs a contact check.

+

Install and measure two resistors.

+

The user sends the contact check LO calibration command.

+

The user sends the contact check HI calibration command.

+
+

Also see

+

Adjustment

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+

smua.contact.calibratelo()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15100.htm b/WebHelpDocs/2601B-PULSE/15100.htm new file mode 100644 index 0000000..e19c648 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15100.htm @@ -0,0 +1,132 @@ + + + + + smua.contact.calibratelo() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.contact.calibratelo()

+

This function adjusts the low/sense low contact check measurement.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.contact.calibratelo(cp1Measured, cp1Reference, cp2Measured, cp2Reference)

+

+ + + + + + + + + + + + + + + + + + +

cp1Measured

+

The value measured by this SMU for point 1

+

cp1Reference

+

The reference measurement for point 1 as measured externally

+

cp2Measured

+

The value measured by this SMU for point 2

+

cp2Reference

+

The reference measurement for point 2 as measured externally

+
+

Details

+

Contact check measurement adjustment does not require range information.

+

Typically, points one and two are near 0 Ω and 50 Ω, respectively.

+

All four measurements (cp1Measured, cp1Reference, cp2Measured, and cp2Reference) must be made with the active calibration set. If not, corruption of the calibration constants may result.

+

The new calibration constants are activated immediately but are not written to nonvolatile memory. Use smua.cal.save() to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.

+

This function is disabled until a successful call to smua.cal.unlock() is made.

+

Example

+

+ + + + + + + + +

-- Short SENSE LO and LO terminals.

+

-- Short SENSE HI and HI terminals.

+

-- Allow readings to settle, then get measurements.

+

r0_hi, r0_lo = smua.contact.r()

+

 

+

-- Connect 50 OHM resistor between SENSE LO and LO.

+

-- Connect 50 OHM resistor between SENSE HI and HI.

+

-- Allow readings to settle, then get measurements.

+

r50_hi, r50_lo = smua.contact.r()

+

smua.contact.calibratelo(r0_lo, Z_actual_lo, r50_lo, 50_ohm_actual_lo)

+

smua.contact.calibratehi(r0_hi, Z_actual_hi, r50_hi, 50_ohm_actual_hi)

+

The instrument performs a contact check.

+

Install and measure two resistors.

+

The user sends the contact check LO calibration command.

+

The user sends the contact check HI calibration command.

+
+

Also see

+

Adjustment

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+

smua.contact.calibratehi()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15105.htm b/WebHelpDocs/2601B-PULSE/15105.htm new file mode 100644 index 0000000..ddb2a65 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15105.htm @@ -0,0 +1,102 @@ + + + + + smua.makebuffer() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.makebuffer()

+

This function creates a reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

bufferVar = smua.makebuffer(bufferSize)

+

+ + + + + + + + + + +

bufferVar

+

The created reading buffer

+

bufferSize

+

Maximum number of readings that can be stored

+
+

Details

+

Reading buffers can be created and allocated dynamically using this function. Use bufferSize to designate the number of readings the buffer can store.

+

Dynamically allocated reading buffers can be used interchangeably with the smua.nvbufferY buffers.

+

A reading buffer can be deleted by setting all references to the reading buffer equal to nil, then running the garbage collector (see the collectgarbage() function in Standard libraries).

+

Example

+

+ + + + + + +

mybuffer2 = smua.makebuffer(200)

+

Creates a 200 element reading buffer (mybuffer2).

+
+

Also see

+

collectgarbage() in Base library functions

+

Remote reading buffer programming

+

savebuffer()

+

smua.nvbufferY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15107.htm b/WebHelpDocs/2601B-PULSE/15107.htm new file mode 100644 index 0000000..5f81ea7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15107.htm @@ -0,0 +1,108 @@ + + + + + smua.measure.autorangeY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.autorangeY

+

This attribute stores the measurement autorange setting.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

1 (smua.AUTORANGE_ON)

+
+

Usage

+

autoRange = smua.measure.autorangeY

+

smua.measure.autorangeY = autoRange

+

+ + + + + + + + + + +

autoRange

+

The state of the measurement autorange setting; set to one of the following values:

+
  • 0 or smua.AUTORANGE_OFF: Disabled
  • 1 or smua.AUTORANGE_ON: Enabled
  • 2 or smua.AUTORANGE_FOLLOW_LIMIT: Measure range automatically set to the limit range

Y

+

SMU measure function (v = voltage, i = current)

+
+

Details

+

This attribute indicates the measurement autorange state. Its value is smua.AUTORANGE_OFF when the SMU measure circuit is on a fixed range and smua.AUTORANGE_ON when it is in autorange mode.

+

Setting this attribute to smua.AUTORANGE_OFF puts the SMU on a fixed range. The fixed range is the present SMU measure range.

+

Setting this attribute to smua.AUTORANGE_ON puts the SMU measure circuit in autorange mode. It remains on its present measure range until the next measurement is requested.

+

If source high capacitance mode is enabled, current autorange is set to smua.AUTORANGE_FOLLOW_LIMIT and cannot be changed.

+

Example

+

+ + + + + + + + +

smua.measure.autorangev = smua.AUTORANGE_ON

+

Enables voltage measurement autoranging.

+
+

Also see

+

Autoranging

+

Range

+

reset()

+

setup.recall()

+

smua.measure.rangeY

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15109.htm b/WebHelpDocs/2601B-PULSE/15109.htm new file mode 100644 index 0000000..18f737f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15109.htm @@ -0,0 +1,133 @@ + + + + + smua.measure.calibrateY() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.calibrateY()

+

This function generates and activates new measurement calibration constants.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.measure.calibrateY(range, cp1Measured, cp1Reference, cp2Measured, cp2Reference)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

Y

+

SMU measurement function (v = voltage, i = current)

+

range

+

The measurement range to adjust

+

cp1Measured

+

The value measured by this SMU for point 1

+

cp1Reference

+

The reference measurement for point 1 as measured externally

+

cp2Measured

+

The value measured by this SMU for point 2

+

cp2Reference

+

The reference measurement for point 2 as measured externally

+
+

Details

+

This function generates and activates new calibration constants for the given range.

+

The positive and negative polarities of the instrument must be adjusted separately. Use a positive value for range to adjust the positive polarity and a negative value for range to adjust the negative polarity.

+

Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.

+

All four measurements (cp1Measured, cp1Reference, cp2Measured, and cp2Reference) must be made with the calibration set that is active. Corruption of the calibration constants may result if this is ignored.

+

The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.

+

This function is only available when calibration is unlocked using smua.cal.unlock().

+

Example

+

+ + + + + + + + +

smua.measure.calibratev(1, 1e-4, 1e-5, 0.92, 0.903)

+

Adjust SMU channel A voltage measurement using the following values:

+
  • 1 V calibration range
  • 1e-4 for +zero measurement reading
  • 1e-5 for +zero DMM measurement reading
  • 0.92 for +FS measurement reading
  • 0.903 for the +FS DMM measurement reading
+

Also see

+

Adjustment

+

smua.cal.lock()

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+

smua.source.calibrateY()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15112.htm b/WebHelpDocs/2601B-PULSE/15112.htm new file mode 100644 index 0000000..f69fdc0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15112.htm @@ -0,0 +1,98 @@ + + + + + smua.measure.delayfactor + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.delayfactor

+

This attribute stores a multiplier to the delays that are used when smua.measure.delay is set to smua.DELAY_AUTO.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Not saved

+

1

+
+

Usage

+

delayFactor = smua.measure.delayfactor

+

smua.measure.delayfactor = delayFactor

+

+ + + + + + +

delayFactor

+

The delay factor multiplier

+
+

Details

+

The delay factor is only applied when smua.measure.delay = smua.DELAY_AUTO.

+

This attribute can be set to a value less than 1 (for example, 0.5) to decrease the automatic delay.

+

This attribute can be set to a value greater than 1 (for example, 1.5 or 2.0) to increase the automatic delay.

+

Setting this attribute to zero disables delays when smua.measure.delay = smua.DELAY_AUTO.

+

Example

+

+ + + + + + +

smua.measure.delayfactor = 2.0

+

Doubles the measure delay.

+
+

Also see

+

Measure auto delay

+

reset()

+

smua.measure.delay

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15113.htm b/WebHelpDocs/2601B-PULSE/15113.htm new file mode 100644 index 0000000..5656180 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15113.htm @@ -0,0 +1,103 @@ + + + + + smua.measure.filter.count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.filter.count

+

This command sets the number of measured readings that are required to yield one filtered measurement.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

1

+
+

Usage

+

filterCount = smua.measure.filter.count

+

smua.measure.filter.count = filterCount

+

+ + + + + + +

filterCount

+

The number of readings required for each filtered measurement (1 to 100)

+
+

Details

+

This attribute sets the size of the stack used for filtered measurements.

+

Example

+

+ + + + + + + + +

smua.measure.filter.count = 10

+

smua.measure.filter.type = smua.FILTER_MOVING_AVG

+

smua.measure.filter.enable = smua.FILTER_ON

+

Sets the filter count to 10.

+

Sets the filter type to moving average.

+

Enables the filter.

+
+

Also see

+

Filters

+

reset()

+

setup.recall()

+

smua.measure.filter.enable

+

smua.measure.filter.type

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15114.htm b/WebHelpDocs/2601B-PULSE/15114.htm new file mode 100644 index 0000000..cc648bf --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15114.htm @@ -0,0 +1,103 @@ + + + + + smua.measure.filter.enable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.filter.enable

+

This command enables or disables filtered measurements.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

0 (smua.FILTER_OFF)

+
+

Usage

+

filterState = smua.measure.filter.enable

+

smua.measure.filter.enable = filterState

+

+ + + + + + +

filterState

+

The filter status; set to one of the following values:

+
  • 0 or smua.FILTER_OFF: Disables the filter
  • 1 or smua.FILTER_ON: Enables the filter
+

Details

+

This command enables or disables the filter.

+

Example

+

+ + + + + + + + +

smua.measure.filter.count = 10

+

smua.measure.filter.type = smua.FILTER_MOVING_AVG

+

smua.measure.filter.enable = smua.FILTER_ON

+

Sets the filter count to 10.

+

Sets the filter type to moving average.

+

Enables the filter.

+
+

Also see

+

Filters

+

reset()

+

setup.recall()

+

smua.measure.filter.count

+

smua.measure.filter.type

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15116.htm b/WebHelpDocs/2601B-PULSE/15116.htm new file mode 100644 index 0000000..1e3ab5c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15116.htm @@ -0,0 +1,96 @@ + + + + + smua.measure.highcrangedelayfactor + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.highcrangedelayfactor

+

This attribute contains a delay multiplier that is only used during range changes when the high-capacitance mode is active.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

10

+
+

Usage

+

delayFactor = smua.measure.highcrangedelayfactor

+

smua.measure.highcrangedelayfactor = delayFactor

+

+ + + + + + +

delayFactor

+

The delay factor; set to a value between 1 and 99

+
+

Details

+

This delay multiplier is only active when the high-capacitance mode is active.

+

Example

+

+ + + + + + +

smua.measure.highcrangedelayfactor = 5

+

Increases the delay used during range changes by a factor of 5.

+
+

Also see

+

High-capacitance mode

+

reset()

+

setup.recall()

+

smua.reset()

+

smua.source.highc

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15120.htm b/WebHelpDocs/2601B-PULSE/15120.htm new file mode 100644 index 0000000..b6a3f16 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15120.htm @@ -0,0 +1,118 @@ + + + + + smua.measure.overlappedY() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.overlappedY()

+

This function starts an asynchronous (background) measurement.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

smua.measure.overlappedY(rbuffer)

+

smua.measure.overlappediv(ibuffer, vbuffer)

+

+ + + + + + + + + + + + + + + + + + +

Y

+

SMU measurement type (v = voltage, i = current, r = resistance, p = power)

+

rbuffer

+

A reading buffer object where the readings are stored

+

ibuffer

+

A reading buffer object where current readings are stored

+

vbuffer

+

A reading buffer object where voltage readings are stored

+
+

Details

+

This function starts a measurement and returns immediately. The measurements, as they are performed, are stored in a reading buffer (along with any other information that is being acquired). If the instrument is configured to return multiple readings where one is requested, the readings are available as they are made. Measurements are in the following units of measure: v = volts, i = amperes, r = ohms, p = watts.

+

The second form of this function, smua.measure.overlappediv(), stores current readings in ibuffer and voltage readings in vbuffer.

+

This function is an overlapped command. Script execution continues while the measurements are made in the background. Attempts to access result values that have not yet been generated cause the script to block and wait for the data to become available. The waitcomplete() function can also be used to wait for the measurements to complete before continuing.

+

If a given reading buffer contains any data, it is cleared before making any measurements, unless the reading buffer has been configured to append data.

+

Example

+

+ + + + + + + + +

smua.measure.overlappedv(smua.nvbuffer1)

+

Starts background voltage measurements.

+
+

Also see

+

Reading buffers

+

smua.measure.Y()

+

smua.nvbufferY

+

waitcomplete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15122.htm b/WebHelpDocs/2601B-PULSE/15122.htm new file mode 100644 index 0000000..83a90b7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15122.htm @@ -0,0 +1,139 @@ + + + + + smua.measure.Y() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.Y()

+

This function makes one or more measurements.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

reading = smua.measure.Y()

+

reading = smua.measure.Y(readingBuffer)

+

iReading, vReading = smua.measure.iv()

+

iReading, vReading = smua.measure.iv(iReadingBuffer)

+

iReading, vReading = smua.measure.iv(iReadingBuffer, vReadingBuffer)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

reading

+

Returned value of the last (or only) reading of the measurement process

+

Y

+

SMU measurement function (v = voltage, i = current, r = resistance, p = power)

+

readingBuffer

+

A reading buffer object where all readings are stored

+

iReading

+

The last reading of the current measurement process

+

vReading

+

The last reading of the voltage measurement process

+

iReadingBuffer

+

A reading buffer object where current readings are stored

+

vReadingBuffer

+

A reading buffer object where voltage readings are stored

+
+

Details

+

If you use this function without specifying a reading buffer, it makes one measurement and returns that measurement as reading. To use the additional information that is acquired while making a measurement or to return multiple readings, specify a reading buffer. If the instrument is configured to return multiple readings for a measurement and readingBuffer is specified, all readings are available in readingBuffer, but only the last measurement is returned as reading.

+

Measurements are in the following units of measure:

+
  • v = volts
  • i = amperes
  • r = ohms
  • p = watts

The smua.measure.iv() function returns the last actual current measurement and voltage measurement as iReading and vReading, respectively. Additionally, it can store current and voltage readings if buffers are provided (iReadingBuffer and vReadingBuffer ).

+

The smua.measure.count attribute determines how many measurements are performed. When using a reading buffer, it also determines the number of readings to store in the buffer. If a reading buffer is not specified, the SMU ignores the smua.measure.count attribute and only makes one measurement.

+

The readingBuffer is cleared before making any measurements unless the buffer is configured to append data.

+

Example

+

+ + + + + + +

smua.measure.count = 10

+

smua.measure.v(smua.nvbuffer1)

+

Makes 10 voltage measurements using SMU channel A and stores them in a buffer.

+
+

Also see

+

Reading buffers

+

smua.measure.count

+

smua.measure.overlappedY()

+

smua.nvbufferY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15123.htm b/WebHelpDocs/2601B-PULSE/15123.htm new file mode 100644 index 0000000..7fa9748 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15123.htm @@ -0,0 +1,103 @@ + + + + + smua.measure.rel.enableY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.rel.enableY

+

This attribute turns relative measurements on or off.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Not saved

+

0 (smua.REL_OFF)

+
+

Usage

+

relEnable = smua.measure.rel.enableY

+

smua.measure.rel.enableY = relEnable

+

+ + + + + + + + + + +

relEnable

+

Relative measurement control. Set relEnable to one of the following values:

+
  • 0 or smua.REL_OFF: Disables relative measurements
  • 1 or smua.REL_ON: Enables relative measurements

Y

+

SMU measurement function (v = voltage, i = current, r = resistance, p = power)

+
+

Details

+

This attribute enables or disables relative measurements. When relative measurements are enabled, all subsequent measured readings are offset by the relative offset value specified by smua.measure.rel.levelY. Each returned measured relative reading is the result of the following calculation:

+

Relative reading = Actual measured reading - Relative offset value

+

Example

+

+ + + + + + +

smua.measure.rel.enablev = smua.REL_ON

+

Enables relative voltage measurements.

+
+

Also see

+

Relative offset

+

reset()

+

setup.recall()

+

smua.measure.rel.levelY

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15124.htm b/WebHelpDocs/2601B-PULSE/15124.htm new file mode 100644 index 0000000..9708701 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15124.htm @@ -0,0 +1,102 @@ + + + + + smua.measure.rel.levelY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.rel.levelY

+

This attribute sets the offset value for relative measurements.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Not saved

+

0

+
+

Usage

+

relValue = smua.measure.rel.levelY

+

smua.measure.rel.levelY = relValue

+

+ + + + + + + + + + +

relValue

+

Relative measurement offset value

+

Y

+

SMU measurement function (v = voltage, i = current, r = resistance, p = power)

+
+

Details

+

This attribute specifies the offset value used for relative measurements. When relative measurements are enabled (see smua.measure.rel.enableY), all subsequent measured readings will be offset by the value of this attribute. Each returned measured relative reading is the result of the following calculation:

+

Relative reading = Actual measured reading - Relative offset value

+

Example

+

+ + + + + + +

smua.measure.rel.levelv = smua.measure.v()

+

Performs a voltage measurement and then uses it as the relative offset value.

+
+

Also see

+

Relative offset

+

reset()

+

smua.measure.rel.enableY

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15127.htm b/WebHelpDocs/2601B-PULSE/15127.htm new file mode 100644 index 0000000..5235827 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15127.htm @@ -0,0 +1,102 @@ + + + + + bufferVar.appendmode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.appendmode

+

This attribute sets the state of the reading buffer's append mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

See Details

+

0 (disabled)

+
+

Usage

+

state = bufferVar.appendmode

+

bufferVar.appendmode = state

+

+ + + + + + + + + + +

state

+

The reading buffer append mode; set to one of the following:

+
  • 0: Append mode off; new measurement data overwrites the previous buffer content
  • 1: Append mode on; appends new measurement data to the present buffer content

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

Assigning a value to this attribute enables or disables the buffer append mode. This value can only be changed with an empty buffer. Use bufferVar.clear() to empty the buffer.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

If the append mode is set to 0, any stored readings in the buffer are cleared before new ones are stored. If append mode is set to 1, any stored readings remain in the buffer and new readings are added to the buffer after the stored readings.

+

With append mode on, the first new measurement is stored at rb[n+1], where n is the number of readings stored in buffer rb.

+

Example

+

+ + + + + + +

buffer1.appendmode = 1

+

Append new readings to contents of the reading buffer named buffer1.

+
+

Also see

+

bufferVar.clear()

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15128.htm b/WebHelpDocs/2601B-PULSE/15128.htm new file mode 100644 index 0000000..7409714 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15128.htm @@ -0,0 +1,110 @@ + + + + + bufferVar.basetimestamp + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.basetimestamp

+

This attribute contains the timestamp that indicates when the first reading was stored in the buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

See Details

+

0

+
+

Usage

+

basetime = bufferVar.basetimestamp

+

+ + + + + + + + + + +

basetime

+

The timestamp of the first stored reading

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+
+

Details

+

This read-only attribute contains the timestamp (in seconds) of the first reading stored in a buffer (rb[1] stored in reading buffer rb). The timestamp is the number of seconds since 12:00 am January 1, 1970 (UTC) that the measurement was performed and stored.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

See the smua.nvbufferY attribute for details on accessing dedicated reading buffers.

+

Example

+

+ + + + + + + + +

basetime = smua.nvbuffer1.basetimestamp

+

print(basetime)

+

Read the timestamp for the first reading

+

stored in dedicated reading buffer 1.

+

Output:

+

1.57020e+09

+

This output indicates that the timestamp is 1,570,200,000 seconds (which is Friday, October, 4, 2019 at 14:40:00 pm).

+
+

Also see

+

Reading buffers

+

smua.measure.overlappedY()

+

smua.measure.Y()

+

smua.nvbufferY

+

smua.trigger.measure.Y()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15129.htm b/WebHelpDocs/2601B-PULSE/15129.htm new file mode 100644 index 0000000..0d32ee8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15129.htm @@ -0,0 +1,110 @@ + + + + + bufferVar.capacity + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.capacity

+

This attribute sets the number of readings a buffer can store.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

See Details

+

Not applicable

+
+

Usage

+

bufferCapacity = bufferVar.capacity

+

+ + + + + + + + + + +

bufferCapacity

+

The maximum number of readings the buffer can store

+

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

This read-only attribute reads the number of readings that can be stored in the buffer.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

The capacity of the buffer does not change as readings fill the buffer. A dedicated reading buffer that only collects basic items can store over 140,000 readings. Turning on additional collection items, such as timestamps and source values, decreases the capacity of a dedicated reading buffer (for example, smua.nvbuffer1), but does not change the capacity of a user-defined dynamically allocated buffer. A user-defined dynamically allocated buffer has a fixed capacity that is set when the buffer is created.

+

See the smua.nvbufferY attribute for details on accessing dedicated reading buffers. See the smua.makebuffer() function for information on creating user-defined dynamically allocated reading buffers.

+

Example

+

+ + + + + + +

bufferCapacity = smua.nvbuffer1.capacity

+

 

+

print(bufferCapacity)

+

Reads the capacity of dedicated reading
buffer 1 (source-measure unit (SMU) channel A).

+

Output:

+

1.49789e+05

+

The above output indicates that the buffer can hold 149789 readings.

+
+

Also see

+

Reading buffers

+

smua.makebuffer()

+

smua.measure.overlappedY()

+

smua.measure.Y()

+

smua.nvbufferY

+

smua.trigger.measure.Y()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15130.htm b/WebHelpDocs/2601B-PULSE/15130.htm new file mode 100644 index 0000000..84234e5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15130.htm @@ -0,0 +1,92 @@ + + + + + bufferVar.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.clear()

+

This function empties the buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

bufferVar.clear()

+

+ + + + + + +

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

This function clears all readings and related recall attributes from the buffer (for example, bufferVar.timestamps and bufferVar.statuses) from the specified buffer.

+

Example

+

+ + + + + + +

smua.nvbuffer1.clear()

+

Clears dedicated reading buffer 1 (source-measure unit (SMU) channel A).

+
+

Also see

+

Reading buffers

+

smua.nvbufferY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15131.htm b/WebHelpDocs/2601B-PULSE/15131.htm new file mode 100644 index 0000000..dad6d44 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15131.htm @@ -0,0 +1,96 @@ + + + + + bufferVar.clearcache() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.clearcache()

+

This function clears the cache.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

bufferVar.clearcache()

+

+ + + + + + +

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

This function clears all readings from the specified cache.

+

If you run successive operations that overwrite reading buffer data, the reading buffer may return stale cache data. This can happen when you:

+
  • Initiate successive sweeps without reconfiguring the sweep measurements. Watch for this when running Lua code remotely on more than one node, because values in the reading buffer cache may change while the Lua code is running.
  • Overwrite data in the reading buffer by setting the bufferVar.fillmode attribute to smua.FILL_WINDOW.

To avoid this, you can include explicit calls to the bufferVar.clearcache() function to remove stale values from the reading buffer cache.

+

Example

+

+ + + + + + +

smua.nvbuffer1.clearcache()

+

Clears the reading buffer cache for dedicated reading buffer 1.

+
+

Also see

+

bufferVar.fillmode

+

Reading buffers

+

Removing stale values from the reading buffer cache

+

smua.nvbufferY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15132.htm b/WebHelpDocs/2601B-PULSE/15132.htm new file mode 100644 index 0000000..dcfa53b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15132.htm @@ -0,0 +1,107 @@ + + + + + bufferVar.collectsourcevalues + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.collectsourcevalues

+

This attribute sets whether or not source values are stored with the readings in the buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

See Details

+

0 (disabled)

+
+

Usage

+

state = bufferVar.collectsourcevalues

+

bufferVar.collectsourcevalues = state

+

+ + + + + + + + + + +

state

+

Source value collection status; set to one of the following:

+
  • 0: Source value collection disabled (off)
  • 1: Source value collection enabled (on)

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+
+

Details

+

Assigning a value to this attribute enables or disables the storage of source values. Reading this attribute returns the state of source value collection. This value can only be changed with an empty buffer. Empty the buffer using the bufferVar.clear() function.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

When on, source values are stored with readings in the buffer. This requires four extra bytes of storage for each reading. Turning on additional collection items, such as source values (this attribute) and timestamps, decreases the capacity of a dedicated reading buffer, but does not change the capacity of a user-defined dynamically allocated buffer.

+

You cannot collect source values when smua.trigger.measure.action is set to smua.ASYNC, so this must be set to 0 when the measurement action is set to be asynchronous.

+

Example

+

+ + + + + + +

smua.nvbuffer1.collectsourcevalues = 1

+

Include source values with readings for dedicated reading buffer 1.

+
+

Also see

+

bufferVar.clear()

+

Reading buffers

+

smua.measure.overlappedY()

+

smua.measure.Y()

+

smua.nvbufferY

+

smua.trigger.measure.action

+

smua.trigger.measure.Y()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15133.htm b/WebHelpDocs/2601B-PULSE/15133.htm new file mode 100644 index 0000000..bd5a7c2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15133.htm @@ -0,0 +1,106 @@ + + + + + bufferVar.collecttimestamps + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.collecttimestamps

+

This attribute sets whether or not timestamp values are stored with the readings in the buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

See Details

+

0 (disabled)

+
+

Usage

+

state = bufferVar.collecttimestamps

+

bufferVar.collecttimestamps = state

+

+ + + + + + + + + + +

state

+

Timestamp value collection status; set to one of the following:

+
  • 0: Timestamp value collection disabled (off)
  • 1: Timestamp value collection enabled (on)

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

Assigning a value to this attribute enables or disables the storage of timestamps. Reading this attribute returns the state of timestamp collection.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

When on, timestamp values are stored with readings in the buffer. This requires four extra bytes of storage for each reading. Turning on additional collection items, such as timestamps (this attribute) and source values, decreases the capacity of a dedicated reading buffer (for example, smua.nvbuffer1), but does not change the capacity of a user-defined dynamically allocated buffer.

+

This value, off (0) or on (1), can only be changed when the buffer is empty. Empty the buffer using the bufferVar.clear() function.

+

Example

+

+ + + + + + +

smua.nvbuffer1.collecttimestamps = 1

+

Include timestamps with readings for dedicated reading buffer 1.

+
+

Also see

+

bufferVar.clear()

+

Reading buffers

+

smua.measure.overlappedY()

+

smua.measure.Y()

+

smua.nvbufferY

+

smua.trigger.measure.Y()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15134.htm b/WebHelpDocs/2601B-PULSE/15134.htm new file mode 100644 index 0000000..e781798 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15134.htm @@ -0,0 +1,118 @@ + + + + + bufferVar.n + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.n

+

This attribute contains the number of readings in the buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

numberOfReadings = bufferVar.n

+

+ + + + + + + + + + +

numberOfReadings

+

The number of readings stored in the buffer

+

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

This read-only attribute contains the number of readings presently stored in the buffer.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example

+

+ + + + + + + + +

numberOfReadings = smua.nvbuffer1.n

+

print(numberOfReadings)

+

Reads the number of readings stored in dedicated reading buffer 1 (source-measure unit (SMU) channel A).

+

Output:

+

1.25000+02

+

The above output indicates that there are 125 readings stored in the buffer.

+
+

+

Also see

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+

smua.measure.overlappedY()

+

smua.measure.Y()

+

smua.nvbufferY

+

smua.trigger.measure.Y()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15135.htm b/WebHelpDocs/2601B-PULSE/15135.htm new file mode 100644 index 0000000..9a1f7d7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15135.htm @@ -0,0 +1,108 @@ + + + + + bufferVar.timestampresolution + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.timestampresolution

+

This attribute contains the resolution of the timestamp.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

See Details

+

1e-6 (1 µs)

+
+

Usage

+

resolution = bufferVar.timestampresolution

+

+ + + + + + + + + + +

resolution

+

Timestamp resolution in seconds

+

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

Assigning a value to this attribute sets the resolution for the timestamps. Reading this attribute returns the timestamp resolution value. This value can only be changed with an empty buffer. Empty the buffer using the bufferVar.clear() function.

+

The finest timestamp resolution is 0.000001 seconds (1 μs). At this resolution, the reading buffer can store unique timestamps for up to 71 minutes. This value can be increased for very long tests.

+

The value specified when setting this attribute will be rounded to an even power of 2 µs.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example

+

+ + + + + + +

smua.nvbuffer1.timestampresolution = 0.000008

+

 

+

Sets the timestamp resolution of dedicated reading buffer 1 to 8 μs.

+
+

Also see

+

bufferVar.clear()

+

bufferVar.collecttimestamps

+

bufferVar.timestamps

+

Reading buffers

+

smua.measure.overlappedY()

+

smua.measure.Y()

+

smua.nvbufferY

+

smua.trigger.measure.Y()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15136.htm b/WebHelpDocs/2601B-PULSE/15136.htm new file mode 100644 index 0000000..feadc94 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15136.htm @@ -0,0 +1,81 @@ + + + + + smua.reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.reset()

+

This function turns off the output and resets the commands that begin with smua. to their default settings.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.reset()

+

Details

+

This function turns off the output and returns the specified SMU to its default settings.

+

Example

+

+ + + + + + +

smua.reset()

+

Turns off the output and resets SMU to its default settings.

+
+

Also see

+

reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15137.htm b/WebHelpDocs/2601B-PULSE/15137.htm new file mode 100644 index 0000000..8093deb --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15137.htm @@ -0,0 +1,94 @@ + + + + + smua.savebuffer() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.savebuffer()

+

This function saves one source-measure unit (SMU) dedicated reading buffer to nonvolatile memory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.savebuffer(smua.nvbufferY)

+

+ + + + + + +

Y

+

SMU dedicated reading buffer (1 or 2)

+
+

Details

+

When the instrument is turned off and back on, the dedicated reading buffers are restored from nonvolatile memory to their last saved values.

+

Example

+

+ + + + + + +

smua.savebuffer(smua.nvbuffer1)

+

 

+

Saves buffer 1 to internal memory.

+
+

Also see

+

Reading buffers

+

savebuffer()

+

smua.nvbufferY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15139.htm b/WebHelpDocs/2601B-PULSE/15139.htm new file mode 100644 index 0000000..bcdc1fc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15139.htm @@ -0,0 +1,103 @@ + + + + + smua.source.autorangeY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.autorangeY

+

This attribute contains the state of the source autorange control (on/off).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

1 (smua.AUTORANGE_ON)

+
+

Usage

+

sourceAutorange = smua.source.autorangeY

+

smua.source.autorangeY = sourceAutorange

+

+ + + + + + + + + + +

sourceAutorange

+

The state of the source autorange control. Set to one of the following:

+
  • 0 or smua.AUTORANGE_OFF: Disables source autorange
  • 1 or smua.AUTORANGE_ON: Enables source autorange

Y

+

SMU source function (v = voltage, i = current)

+
+

Details

+

This attribute indicates the source autorange state. Its value is smua.AUTORANGE_OFF when the SMU source circuit is on a fixed range and smua.AUTORANGE_ON when it is in autorange mode.

+

Setting this attribute to smua.AUTORANGE_OFF puts the SMU on a fixed source range. The fixed range used is the present SMU source circuit range.

+

Setting this attribute to smua.AUTORANGE_ON puts the SMU source circuit into autorange mode. If the source output is on, the SMU immediately changes range to the range most appropriate for the value being sourced if that range is different than the present SMU range.

+

Autorange is disabled if the source level is edited from the front panel. Setting the source range also turns off autorange when set by using the smua.source.rangeY attribute.

+

Resetting the instrument selects the smua.AUTORANGE_ON.

+

Example

+

+ + + + + + +

smua.source.autorangev = smua.AUTORANGE_ON

+

Enables volts source autorange.

+
+

Also see

+

smua.measure.autorangeY

+

smua.source.rangeY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15141.htm b/WebHelpDocs/2601B-PULSE/15141.htm new file mode 100644 index 0000000..9a3847a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15141.htm @@ -0,0 +1,98 @@ + + + + + smua.source.compliance + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.compliance

+

This attribute contains the state of source compliance.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+
+

Usage

+

compliance = smua.source.compliance

+

+ + + + + + +

compliance

+

The state of source compliance:

+
  • true: Indicates that the limit function is in control of the source (source in compliance)
  • false: Indicates that the source function is in control of the output (source not in compliance)
+

Details

+

Reading this attribute updates the status model and the front panel with generated compliance information. See Current Limit (ILMT) in the status model diagram for the Measurement event registers. The Voltage Limit (VLMT) is not shown in the status model diagram for the Measurement event registers, but is similar to the Current Limit (ILMT).

+

Example

+

+ + + + + + + + +

compliance = smua.source.compliance

+

 

+

print(compliance)

+

Reads the source compliance state.

+

Output:

+

true

+

This output indicates that a configured limit has been reached (voltage, current, or power limit).

+
+

Also see

+

smua.source.limitY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15142.htm b/WebHelpDocs/2601B-PULSE/15142.htm new file mode 100644 index 0000000..6927c74 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15142.htm @@ -0,0 +1,98 @@ + + + + + smua.source.delay + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.delay

+

This attribute contains the source delay.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.DELAY_OFF)

+
+

Usage

+

sDelay = smua.source.delay

+

smua.source.delay = sDelay

+

+ + + + + + +

sDelay

+

Set to the source delay value (for example, to specify an additional 10 ms source delay, set the value to 0.010); you can also set it one of the following values:

+
  • 0 or smua.DELAY_OFF: No delay
  • -1 or smua.DELAY_AUTO: Automatic delay value
+

Details

+

This attribute allows for additional delay (settling time) after an output step.

+

The smua.DELAY_AUTO setting causes a range-dependent delay to be inserted when the source is changed. Range-dependent delays are based on the output settling time values as defined in the 2601B-PULSE specifications.

+

Example

+

+ + + + + + + + +

smua.source.delay = smua.DELAY_AUTO

+

Sets the delay to automatic (a range-dependent delay is inserted whenever the source is changed).

+
+

Also see

+

reset()

+

smua.measure.count

+

smua.measure.delay

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15143.htm b/WebHelpDocs/2601B-PULSE/15143.htm new file mode 100644 index 0000000..d0e0be7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15143.htm @@ -0,0 +1,132 @@ + + + + + smua.source.calibrateY() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.calibrateY()

+

This function generates and activates new source calibration constants.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.source.calibrateY(range, cp1Expected, cp1Reference, cp2Expected, cp2Reference)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

Y

+

SMU source function (v = voltage, i = current)

+

range

+

The measurement range to adjust

+

cp1Expected

+

The source value set for point 1

+

cp1Reference

+

The reference measurement for point 1 as measured externally

+

cp2Expected

+

The source value set for point 2

+

cp2Reference

+

The reference measurement for point 2 as measured externally

+
+

Details

+

This function generates and activates new calibration constants for the given range.

+

The positive and negative polarities of the source must be adjusted separately. Use a positive value for range to adjust the positive polarity and a negative value for range to adjust the negative polarity. Do not use 0.0 for a negative point; 0.0 is considered to be a positive number.

+

Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.

+

The two reference measurements must be made with the source using the active calibration set. For example, source a value, measure it, and do not change the active calibration set before issuing this command.

+

The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.

+

This function is only available when calibration is unlocked using smua.cal.unlock().

+

Example

+

+ + + + + + + + +

smua.source.calibratev(1, 1e-10, 1e-5, 0.9, 0.903)

+

Generates and activates new source calibration constants for the 1 A range. For point 1, it uses 1e-10 as the source value and 1e-5 as the reference measurement. For point 2, it uses 0.9 for the source value and 0.903 for the reference measurement.

+
+

Also see

+

Calibration

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+

smua.measure.calibrateY()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15144.htm b/WebHelpDocs/2601B-PULSE/15144.htm new file mode 100644 index 0000000..4a050c2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15144.htm @@ -0,0 +1,93 @@ + + + + + smua.source.func + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.func

+

This attribute contains the source function, which can be voltage or current.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

1 (smua.OUTPUT_DCVOLTS)

+
+

Usage

+

sFunction = smua.source.func

+

smua.source.func = sFunction

+

+ + + + + + +

sFunction

+

The source function; set to one of the following values:

+
  • 0 or smua.OUTPUT_DCAMPS: Selects the current source function
  • 1 or smua.OUTPUT_DCVOLTS: Selects the voltage source function
+

Details

+

Reading this attribute indicates the output function of the source. Setting this attribute configures the SMU as either a voltage source or a current source.

+

Example

+

+ + + + + + +

smua.source.func = smua.OUTPUT_DCAMPS

+

Sets the source function to be a current source.

+
+

Also see

+

smua.source.levelY

+

smua.source.output

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15145.htm b/WebHelpDocs/2601B-PULSE/15145.htm new file mode 100644 index 0000000..9f14416 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15145.htm @@ -0,0 +1,93 @@ + + + + + smua.source.highc + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.highc

+

This attribute enables or disables high-capacitance mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

0 (smua.DISABLE)

+
+

Usage

+

highC = smua.source.highc

+

smua.source.highc = highC

+

+ + + + + + +

highC

+

The state of the high-capacitance mode; set to one of the following values:

+
  • 0 or smua.DISABLE: Disables high-capacitance mode
  • 1 or smua.ENABLE: Enables high-capacitance mode
+

Details

+

When enabled, the high-capacitance mode has the following effects on the SMU settings:

+
  • smua.measure.autorangei is set to smua.AUTORANGE_FOLLOW_LIMIT and cannot be changed
  • Current ranges below 1 µA are not accessible
  • If smua.source.limiti is less than 1 µA, it is raised to 1 µA
  • If smua.source.rangei is less than 1 µA, it is raised to 1 µA
  • If smua.source.lowrangei is less than 1 µA, it is raised to 1 µA
  • If smua.measure.lowrangei is less than 1 µA, it is raised to 1 µA

VARIABLE - NOTE
High-capacitance mode is not available when the pulser is enabled.

+

Example

+

+ + + + + + +

smua.source.highc = smua.ENABLE

+

Activates high-capacitance mode.

+
+

Also see

+

High-capacitance mode

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15149.htm b/WebHelpDocs/2601B-PULSE/15149.htm new file mode 100644 index 0000000..ce1a496 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15149.htm @@ -0,0 +1,101 @@ + + + + + smua.source.offlimitY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.offlimitY

+

This attribute sets the limit (current or voltage) used when the source-measure unit (SMU) is in normal output-off mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

Current: 1e-3 (1 mA)
Voltage: 40 (40 V)

+
+

Usage

+

sourceLimit = smua.source.offlimitY

+

smua.source.offlimitY = sourceLimit

+

+ + + + + + + + + + +

sourceLimit

+

Set to the limit to be used when the SMU is in normal output-off mode

+

Y

+

SMU source function (v = voltage, i = current)

+
+

Details

+

Setting the current limit to lower than 1 mA may interfere with operation of the contact check function. See smua.contact.check() and smua.contact.r() for details.

+

Example

+

+ + + + + + +

smua.source.offlimiti = 10e-3

+

Changes the normal output-off mode limit to 10 mA.

+
+

Also see

+

smua.contact.check()

+

smua.contact.r()

+

smua.source.offfunc

+

smua.source.offmode

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15151.htm b/WebHelpDocs/2601B-PULSE/15151.htm new file mode 100644 index 0000000..f04d5de --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15151.htm @@ -0,0 +1,96 @@ + + + + + smua.source.output + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.output

+

This attribute enables or disables the source output.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.OUTPUT_OFF)

+
+

Usage

+

sourceOutput = smua.source.output

+

smua.source.output = sourceOutput

+

+ + + + + + +

sourceOutput

+

The output state setting of the source; set to one of the following values:

+
  • 0 or smua.OUTPUT_OFF: Turns off the source output
  • 1 or smua.OUTPUT_ON: Turns on the source output
  • 2 or smua.OUTPUT_HIGH_Z: Turns off the output in high Z mode (allows you to go to high Z mode without first setting the smua.source.offmode attribute to smua.OUTPUT_HIGH_Z)
+

Details

+

Reading this attribute returns the output state of the source. Setting this attribute switches the output of the source on or off.

+

When the output is switched on, the SMU sources either voltage or current, as set by smua.source.func.

+

Setting this attribute to smua.OUTPUT_HIGH_Z causes the output to turn off and go to the High Z mode. If the smua.source.output is read after setting this attribute to smua.OUTPUT_HIGH_Z, it returns 0.

+

Example

+

+ + + + + + +

smua.source.output = smua.OUTPUT_ON

+

Turns on the source output.

+
+

Also see

+

DUT test connections

+

smua.source.func

+

smua.source.offmode

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15155.htm b/WebHelpDocs/2601B-PULSE/15155.htm new file mode 100644 index 0000000..d1a0c49 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15155.htm @@ -0,0 +1,92 @@ + + + + + smua.source.sink + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.sink

+

This attribute turns sink mode on or off.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

0 (smua.DISABLE)

+
+

Usage

+

sinkMode = smua.source.sink

+

smua.source.sink = sinkMode

+

+ + + + + + +

sinkMode

+

Sets the sink mode on or off; set to one of the following values:

+
  • 0 or smua.DISABLE: Turns off sink mode
  • 1 or smua.ENABLE: Turns on sink mode
+

Details

+

This attribute enables or disables sink mode. When sink mode is enabled, it reduces the source limit inaccuracy that occurs when operating in quadrants II and IV (quadrants I and III will show this source limit inaccuracy).

+

Example

+

+ + + + + + +

smua.source.sink = smua.ENABLE

+

Enables sink mode.

+
+

Also see

+

Source or sink

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15156.htm b/WebHelpDocs/2601B-PULSE/15156.htm new file mode 100644 index 0000000..377ef0c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15156.htm @@ -0,0 +1,95 @@ + + + + + smua.trigger.arm.count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.arm.count

+

This attribute sets the arm count in the trigger model.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

1

+
+

Usage

+

triggerArmCount = smua.trigger.arm.count

+

smua.trigger.arm.count = triggerArmCount

+

+ + + + + + +

triggerArmCount

+

The arm count in the trigger model

+
+

Details

+

During a sweep, the SMU iterates through the arm layer of the trigger model this many times. After performing this many iterations, the SMU returns to an idle state.

+

If this count is set to zero, the SMU stays in the trigger model indefinitely until aborted.

+

Example

+

+ + + + + + + + +

smua.trigger.arm.count = 5

+

Sets the SMU to iterate through the arm layer of the trigger model five times and then return to the idle state.

+
+

Also see

+

smua.trigger.count

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15157.htm b/WebHelpDocs/2601B-PULSE/15157.htm new file mode 100644 index 0000000..455007c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15157.htm @@ -0,0 +1,87 @@ + + + + + smua.trigger.arm.set() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.arm.set()

+

This function sets the arm event detector to the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.arm.set()

+

Details

+

The SMU automatically clears all the event detectors when the smua.trigger.initiate() function is executed. This function should be called after the sweep is initiated.

+

A common example of when this function can be used is when you want the SMU to immediately perform an action the first time through the trigger model even if a programmed trigger event does not occur.

+

This function can also be used to start actions on the SMU in case of a missed trigger event.

+

Example

+

+ + + + + + + + +

smua.trigger.arm.set()

+

Sets the arm event detector to the detected state.

+
+

Also see

+

smua.trigger.initiate()

+

smua.trigger.measure.set()

+

smua.trigger.source.set()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15158.htm b/WebHelpDocs/2601B-PULSE/15158.htm new file mode 100644 index 0000000..afb83cd --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15158.htm @@ -0,0 +1,205 @@ + + + + + smua.trigger.arm.stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.arm.stimulus

+

This attribute selects the event that will cause the arm event detector to enter the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0

+
+

Usage

+

eventID = smua.trigger.arm.stimulus

+

smua.trigger.arm.stimulus = eventID

+

+ + + + + + +

eventID

+

Event that triggers the arm detector

+
+

Details

+

Set this attribute to the event ID of any trigger event generator to wait for that event.

+

Set this attribute to zero to bypass waiting for events at the arm event detector (the SMU continues uninterrupted through the remote trigger model). Set eventID to one of the existing trigger event IDs shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Example

+

+ + + + + + + + +

smua.trigger.arm.stimulus = trigger.timer[1].EVENT_ID

+

An event on trigger timer 1 causes the arm event detector to enter the detected state.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15159.htm b/WebHelpDocs/2601B-PULSE/15159.htm new file mode 100644 index 0000000..94f5161 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15159.htm @@ -0,0 +1,93 @@ + + + + + smua.trigger.ARMED_EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.ARMED_EVENT_ID

+

This constant contains the number of the armed event.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = smua.trigger.ARMED_EVENT_ID

+

+ + + + + + +

eventID

+

The armed event number

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to armed events from this SMU.

+

Example

+

+ + + + + + + + +

trigger.timer[1].stimulus = smua.trigger.ARMED_EVENT_ID

+

Trigger timer when the SMU passes through the arm layer.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15160.htm b/WebHelpDocs/2601B-PULSE/15160.htm new file mode 100644 index 0000000..b1aa666 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15160.htm @@ -0,0 +1,97 @@ + + + + + smua.trigger.autoclear + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.autoclear

+

This attribute turns automatic clearing of the event detectors on or off.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.DISABLE)

+
+

Usage

+

autoClear = smua.trigger.autoclear

+

smua.trigger.autoclear = autoClear

+

+ + + + + + +

autoClear

+

Auto clear setting; set to one of the following values:

+
  • 0 or smua.DISABLE: Turns off automatic clearing of the event detectors
  • 1 or smua.ENABLE: Turns on automatic clearing of the event detectors
+

Details

+

This attribute enables or disables automatic clearing of the trigger model state machine event detectors when the SMU transitions from the arm layer to the trigger layer.

+

Only the detected states of the event detectors are cleared.

+

The overrun statuses of the event detectors are not automatically cleared when the SMU transitions from the arm layer to the trigger layer.

+

The event detectors are always cleared when a sweep is initiated.

+

Example

+

+ + + + + + + + +

smua.trigger.autoclear = smua.ENABLE

+

Automatically clear the event detectors for the trigger mode state.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15161.htm b/WebHelpDocs/2601B-PULSE/15161.htm new file mode 100644 index 0000000..6c773d7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15161.htm @@ -0,0 +1,129 @@ + + + + + smua.trigger.count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.count

+

This attribute sets the trigger count in the trigger model.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

1

+
+

Usage

+

triggerCount = smua.trigger.count

+

smua.trigger.count = triggerCount

+

+ + + + + + +

triggerCount

+

The trigger count is the number of times the source-measure unit (SMU) will iterate in the trigger layer for any given sweep

+
+

Details

+

During a sweep, the SMU iterates through the trigger layer of the trigger model this many times. After performing this many iterations, the SMU returns to the arm layer.

+

If this count is set to zero (0), the SMU stays in the trigger model indefinitely until aborted.

+

Example

+

+ + + + + + + + +

reset()

+

period_timer = trigger.timer[1]

+

pulse_timer = trigger.timer[2]

+

smua.trigger.source.listv( {5} )

+

smua.trigger.source.action = smua.ENABLE

+

smua.source.rangev = 5

+

smua.trigger.measure.action = smua.DISABLE

+

pulse_timer.delay = 0.0006

+

pulse_timer.stimulus = period_timer.EVENT_ID

+

pulse_timer.count = 1

+

period_timer.delay = 0.005

+

period_timer.count = 9

+

period_timer.stimulus = smua.trigger.SWEEPING_EVENT_ID

+

period_timer.passthrough = true

+

smua.trigger.source.stimulus = period_timer.EVENT_ID

+

smua.trigger.endpulse.action = smua.SOURCE_IDLE

+

smua.trigger.endpulse.stimulus = pulse_timer.EVENT_ID

+

smua.trigger.count = 1

+

smua.trigger.arm.count = 10

+

smua.source.output = smua.OUTPUT_ON

+

smua.trigger.initiate()

+

waitcomplete()

+

smua.source.output = smua.OUTPUT_OFF

+

Generate a 10-point pulse train where each pulse has a width of 600 µs and a pulse period of 5 ms.

+

Alias the trigger timers to use for pulse width and period.

+

Create a fixed level voltage sweep.

+

Set the pulse width and trigger the pulse width timer with a period timer.

+

Set the pulse period to output one pulse per period and the count to generate 10 pulses.

+

Trigger the pulse period timer when a sweep is initiated.

+

Configure the timer to output a trigger event when it starts the first delay.

+

Trigger the SMU source action using pulse period timer.

+

Trigger the SMU end pulse action using pulse width timer.

+

Set the trigger model counts.

+

Configure the SMU to execute a 10-point pulse train.

+

Start the trigger model.

+

Wait for the sweep to complete.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15163.htm b/WebHelpDocs/2601B-PULSE/15163.htm new file mode 100644 index 0000000..61dc5d1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15163.htm @@ -0,0 +1,120 @@ + + + + + smua.trigger.endpulse.set() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.endpulse.set()

+

This function sets the end pulse event detector to the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.endpulse.set()

+

Details

+

This function sets the end pulse event detector to the detected state.

+

The SMU automatically clears all the event detectors when the smua.trigger.initiate() function is executed. Therefore, smua.trigger.endpulse.set() should be called after the sweep is initiated. If the event detectors are configured to clear automatically because the smua.trigger.autoclear attribute is set to smua.ENABLE, make sure that smua.trigger.endpulse.set() is issued after the SMU has entered the trigger layer.

+

Example

+

+ + + + + + + + +

reset()

+

period_timer = trigger.timer[1]

+

pulse_timer = trigger.timer[2]

+

smua.trigger.source.listv( {5} )

+

smua.trigger.source.action = smua.ENABLE

+

smua.source.rangev = 5

+

smua.trigger.measure.action = smua.DISABLE

+

pulse_timer.delay = 0.0006

+

pulse_timer.stimulus = period_timer.EVENT_ID

+

pulse_timer.count = 1

+

period_timer.delay = 0.005

+

period_timer.count = 9

+

period_timer.stimulus = smua.trigger.SWEEPING_EVENT_ID

+

period_timer.passthrough = true

+

smua.trigger.source.stimulus = period_timer.EVENT_ID

+

smua.trigger.endpulse.action = smua.SOURCE_IDLE

+

smua.trigger.endpulse.stimulus = pulse_timer.EVENT_ID

+

smua.trigger.count = 1

+

smua.trigger.arm.count = 10

+

smua.source.output = smua.OUTPUT_ON

+

smua.trigger.initiate()

+

waitcomplete()

+

smua.source.output = smua.OUTPUT_OFF

+

Generate a 10-point pulse train where each pulse has a width of 600 µs and a pulse period of 5 ms.

+

Alias the trigger timers to use for pulse width and period.

+

Create a fixed level voltage sweep.

+

Set the pulse width and trigger the pulse width timer with a period timer.

+

Set the pulse period to output one pulse per period and the count to generate 10 pulses.

+

Trigger the pulse period timer when a sweep is initiated.

+

Configure the timer to output a trigger event when it starts the first delay.

+

Trigger the SMU source action using pulse period timer.

+

Trigger the SMU end pulse action using pulse width timer.

+

Set the trigger model counts.

+

Configure the SMU to execute a 10-point pulse train.

+

Start the trigger model.

+

Wait for the sweep to complete.

+
+

Also see

+

smua.trigger.autoclear

+

smua.trigger.initiate()

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15165.htm b/WebHelpDocs/2601B-PULSE/15165.htm new file mode 100644 index 0000000..693102b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15165.htm @@ -0,0 +1,205 @@ + + + + + smua.trigger.endpulse.stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.endpulse.stimulus

+

This attribute defines which event will cause the end pulse event detector to enter the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0

+
+

Usage

+

eventID = smua.trigger.endpulse.stimulus

+

smua.trigger.endpulse.stimulus = eventID

+

+ + + + + + +

eventID

+

Set to the event that triggers the end pulse action of the source

+
+

Details

+

Set this attribute to the event ID of any trigger event generator to wait for that event. To bypass waiting for an event, set this value of this attribute to 0. Set eventID to one of the existing trigger event IDs, which are shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Example

+

+ + + + + + + + +

smua.trigger.endpulse.action = smua.SOURCE_IDLE

+

smua.trigger.endpulse.stimulus = trigger.timer[1].EVENT_ID

+

Configure the end pulse action to achieve a pulse and select the event, trigger.timer[1].EVENT_ID, that causes the arm event detector to enter the detected state.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15166.htm b/WebHelpDocs/2601B-PULSE/15166.htm new file mode 100644 index 0000000..2397e50 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15166.htm @@ -0,0 +1,94 @@ + + + + + smua.trigger.endsweep.action + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.endsweep.action

+

This attribute sets the action of the source at the end of a sweep.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.SOURCE_IDLE)

+
+

Usage

+

action = smua.trigger.endsweep.action

+

smua.trigger.endsweep.action = action

+

+ + + + + + +

action

+

The source action at the end of a sweep; set to one of the following values:

+
  • 0 or smua.SOURCE_IDLE: Sets the source level to the programmed (idle) level at the end of the sweep
  • 1 or smua.SOURCE_HOLD: Sets the source level to stay at the level of the last step
+

Details

+

Use this attribute to configure the source action at the end of the sweep. The SMU can be programmed to return to the idle source level or hold the last value of the sweep.

+

Example

+

+ + + + + + + + +

smua.trigger.endsweep.action = smua.SOURCE_IDLE

+

Sets SMU return the source back to the idle source level at the end of a sweep.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15167.htm b/WebHelpDocs/2601B-PULSE/15167.htm new file mode 100644 index 0000000..a2c1e4b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15167.htm @@ -0,0 +1,93 @@ + + + + + smua.trigger.IDLE_EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.IDLE_EVENT_ID

+

This constant contains the idle event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = smua.trigger.IDLE_EVENT_ID

+

+ + + + + + +

eventID

+

The idle event number

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to idle events from this SMU.

+

Example

+

+ + + + + + + + +

trigger.timer[1].stimulus = smua.trigger.IDLE_EVENT_ID

+

Trigger timer 1 when the SMU returns to the idle layer.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15168.htm b/WebHelpDocs/2601B-PULSE/15168.htm new file mode 100644 index 0000000..e63fd9e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15168.htm @@ -0,0 +1,95 @@ + + + + + smua.trigger.initiate() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.initiate()

+

This function initiates a sweep operation.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.initiate()

+

Details

+

This function causes the SMU to clear the four trigger model event detectors and enter its trigger model (moves the SMU from the idle state into the arm layer).

+

To perform source actions during the sweep, before calling this function, it is necessary to configure and enable one of the following sweep source actions:

+
  • smua.trigger.source.linearY()
  • smua.trigger.source.listY()
  • smua.trigger.source.logY()

To make measurements during the sweep, you must also configure and enable the measure action using smua.trigger.measure.Y().

+

If you run this function more than once without reconfiguring the sweep measurements, the caches on the configured measurement reading buffers will hold stale data; use the bufferVar.clearcache() function to remove stale values from the reading buffer cache.

+

This function initiates an overlapped operation.

+

Example

+

+ + + + + + + + +

smua.trigger.initiate()

+

Starts a preconfigured sweep and clears the event detectors.

+
+

Also see

+

bufferVar.clearcache()

+

Configuring and running sweeps

+

smua.trigger.measure.action

+

smua.trigger.measure.Y()

+

smua.trigger.source.action

+

smua.trigger.source.linearY()

+

smua.trigger.source.listY()

+

smua.trigger.source.logY()

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15169.htm b/WebHelpDocs/2601B-PULSE/15169.htm new file mode 100644 index 0000000..b1df4d9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15169.htm @@ -0,0 +1,101 @@ + + + + + smua.trigger.measure.action + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.measure.action

+

This attribute controls measurement actions during a sweep.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.DISABLE)

+
+

Usage

+

action = smua.trigger.measure.action

+

smua.trigger.measure.action = action

+

+ + + + + + +

action

+

The sweep measurement action; set to one of the following values:

+
  • 0 or smua.DISABLE: Do not make measurements during the sweep
  • 1 or smua.ENABLE: Make measurements during the sweep
  • 2 or smua.ASYNC: Make measurements during the sweep, but asynchronously with the source area of the trigger model
+

Details

+

With this attribute enabled (setting action to smua.ENABLE or smua.ASYNC), configure the measurement with one of the smua.trigger.measure.Y() functions.

+

If this attribute is set to smua.ASYNC:

+
  • Asynchronous sweep measurements can only be used with measure autoranging turned off. To turn measure autoranging off for all measurements during the sweep, set the smua.measure.autorangeY attribute to smua.AUTORANGE_OFF.
  • Autozero must also be turned off. To turn off autozero, set the smua.measure.autozero attribute to smua.AUTOZERO_OFF or smua.AUTOZERO_ONCE.
  • The reading buffer used by smua.trigger.measure.Y() must have bufferVar.collectsourcevalues set to 0.

If any of the above items is incorrectly configured, the smua.trigger.initiate() function generates an error.

+

Example

+

+ + + + + + + + +

smua.trigger.measure.v(smua.nvbuffer1)

+

smua.trigger.measure.action = smua.ENABLE

+

Configure sweep voltage measurements.

+

Enable voltage measurements during the sweep.

+
+

Also see

+

bufferVar.collectsourcevalues

+

smua.trigger.autoclear

+

smua.trigger.measure.Y()

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15170.htm b/WebHelpDocs/2601B-PULSE/15170.htm new file mode 100644 index 0000000..9667c29 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15170.htm @@ -0,0 +1,87 @@ + + + + + smua.trigger.measure.set() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.measure.set()

+

This function sets the measurement event detector to the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.measure.set()

+

Details

+

This function is useful whenever you want the SMU to continue operation without waiting for a programmed trigger event. When called, this function immediately satisfies the event detector, allowing the SMU to continue through the trigger model.

+

For example, you might use this function to have the SMU immediately perform an action the first time through the trigger model, even if a programmed trigger event does not occur.

+

If the event detectors are configured to clear automatically because the smua.trigger.autoclear attribute is set to smua.ENABLE, make sure that smua.trigger.measure.set() is issued after the SMU has entered the trigger layer. This function can also be used to start actions on the SMU in case of a missed trigger event.

+

The SMU automatically clears all event detectors when the smua.trigger.initiate() function is executed. This function should be called after the sweep is initiated.

+

Example

+

+ + + + + + +

smua.trigger.measure.set()

+

Sets the measure event detector.

+
+

Also see

+

smua.trigger.arm.set()

+

smua.trigger.autoclear

+

smua.trigger.endpulse.set()

+

smua.trigger.source.set()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15171.htm b/WebHelpDocs/2601B-PULSE/15171.htm new file mode 100644 index 0000000..cda0137 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15171.htm @@ -0,0 +1,205 @@ + + + + + smua.trigger.measure.stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.measure.stimulus

+

This attribute selects the event that causes the measure event detector to enter the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0

+
+

Usage

+

eventID = smua.trigger.measure.stimulus

+

smua.trigger.measure.stimulus = eventID

+

+ + + + + + +

eventID

+

Event that triggers the measurement detector

+
+

Details

+

Set this attribute to the event ID of any trigger event generator to wait for that event. When set, the SMU waits for the event at the measurement event detector portion of the trigger model.

+

Set this attribute to zero to bypass waiting for an event (the SMU continues uninterrupted through the remote trigger model). Set eventID to one of the existing trigger event IDs shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Example

+

+ + + + + + + + +

smua.trigger.measure.stimulus = trigger.timer[1].EVENT_ID

+

Sets delay before measurement begins.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15172.htm b/WebHelpDocs/2601B-PULSE/15172.htm new file mode 100644 index 0000000..bf9e407 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15172.htm @@ -0,0 +1,120 @@ + + + + + smua.trigger.measure.Y() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.measure.Y()

+

This function configures the measurements that are to be made in a subsequent sweep.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.measure.Y(rbuffer)

+

smua.trigger.measure.iv(ibuffer, vbuffer)

+ + + + + + + + + + + + + + + + + + +

Y

+

SMU measurement type (v = voltage, i = current, r = resistance, p = power)

+

rbuffer

+

A reading buffer object where the readings will be stored

+

ibuffer

+

A reading buffer object where current readings will be stored

+

vbuffer

+

A reading buffer object where voltage readings will be stored

+
+

Details

+

As measurements are made, they are stored in a reading buffer. If the instrument is configured to return multiple readings where one is requested, the readings are available as they are made. Measurements are in the following units of measure: v = volts, i = amperes, r = ohms, p = watts.

+

The smua.trigger.measure.iv() function stores current readings in ibuffer and voltage readings in vbuffer.

+

If a given reading buffer contains any data, it is cleared before making any measurements, unless the reading buffer has been configured to append data.

+

The SMU only retains the last call to any one of these functions and only that measurement action is performed.

+

After configuring the measurements to make with this function, enable the measurement action.

+

Example

+

+ + + + + + +

smua.trigger.measure.v(vbuffername)

+

smua.trigger.measure.action = smua.ENABLE

+

Stores voltage readings during the sweep in buffer vbuffername.

+
+

Also see

+

Reading buffers

+

smua.measure.Y()

+

smua.nvbufferY

+

smua.trigger.measure.action

+

Sweep Operation

+

Triggering

+

waitcomplete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15173.htm b/WebHelpDocs/2601B-PULSE/15173.htm new file mode 100644 index 0000000..367f4ef --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15173.htm @@ -0,0 +1,93 @@ + + + + + smua.trigger.MEASURE_COMPLETE_EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

This constant contains the measurement complete event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

+ + + + + + +

eventID

+

The measurement complete event number

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to measure complete events from this SMU.

+

Example

+

+ + + + + + + + +

trigger.timer[1].stimulus = smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Trigger the timer when the SMU completes a measurement.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15174.htm b/WebHelpDocs/2601B-PULSE/15174.htm new file mode 100644 index 0000000..2cf210c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15174.htm @@ -0,0 +1,93 @@ + + + + + smua.trigger.PULSE_COMPLETE_EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

This constant contains the pulse complete event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = smua.trigger.PULSE_COMPLETE_EVENT_ID

+

+ + + + + + +

eventID

+

The pulse complete event number

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to pulse complete events.

+

Example

+

+ + + + + + + + +

trigger.timer[1].stimulus = smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Trigger a timer when the SMU completes a pulse.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15175.htm b/WebHelpDocs/2601B-PULSE/15175.htm new file mode 100644 index 0000000..dd9e3c0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15175.htm @@ -0,0 +1,93 @@ + + + + + smua.trigger.SOURCE_COMPLETE_EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

This constant contains the source complete event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

+ + + + + + +

eventID

+

The source action complete event number

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to source complete events from this source-measure unit (SMU).

+

Example

+

+ + + + + + + + +

trigger.timer[1].stimulus = smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Trigger the timer when the SMU updates the source level or starts a pulse.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15176.htm b/WebHelpDocs/2601B-PULSE/15176.htm new file mode 100644 index 0000000..994d0fc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15176.htm @@ -0,0 +1,100 @@ + + + + + smua.trigger.SWEEP_COMPLETE_EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

This constant contains the sweep complete event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

+ + + + + + +

eventID

+

The sweep complete event number

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to sweep complete events from this SMU.

+

Example

+

+ + + + + + + + +

digio.trigger[2].mode = digio.TRIG_RISINGA

+

digio.trigger[2].clear()

+

smua.trigger.source.stimulus = digio.trigger[2].EVENT_ID

+

digio.trigger[4].mode = digio.TRIG_RISINGM

+

digio.trigger[4].pulsewidth = 0.001

+

digio.trigger[4].stimulus = smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Configure the 2601B-PULSE to detect a rising edge on digital I/O line 2.

+

Configure SMU A to start its source action when a trigger event occurs on digital I/O line 2.

+

Configure digital I/O line 4 to output a 1 ms rising-edge trigger pulse at the completion of the SMU sweep.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15177.htm b/WebHelpDocs/2601B-PULSE/15177.htm new file mode 100644 index 0000000..9b17487 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15177.htm @@ -0,0 +1,127 @@ + + + + + smua.trigger.SWEEPING_EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.SWEEPING_EVENT_ID

+

This constant contains the sweeping event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = smua.trigger.SWEEPING_EVENT_ID

+

+ + + + + + +

eventID

+

The sweeping event number

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to sweeping events from this SMU.

+

Example

+

+ + + + + + + + +

reset()

+

period_timer = trigger.timer[1]

+

pulse_timer = trigger.timer[2]

+

smua.trigger.source.listv( {5} )

+

smua.trigger.source.action = smua.ENABLE

+

smua.source.rangev = 5

+

smua.trigger.measure.action = smua.DISABLE

+

pulse_timer.delay = 0.0006

+

pulse_timer.stimulus = period_timer.EVENT_ID

+

pulse_timer.count = 1

+

period_timer.delay = 0.005

+

period_timer.count = 9

+

period_timer.stimulus = smua.trigger.SWEEPING_EVENT_ID

+

period_timer.passthrough = true

+

smua.trigger.source.stimulus = period_timer.EVENT_ID

+

smua.trigger.endpulse.action = smua.SOURCE_IDLE

+

smua.trigger.endpulse.stimulus = pulse_timer.EVENT_ID

+

smua.trigger.count = 1

+

smua.trigger.arm.count = 10

+

smua.source.output = smua.OUTPUT_ON

+

smua.trigger.initiate()

+

waitcomplete()

+

smua.source.output = smua.OUTPUT_OFF

+

Generate a 10-point pulse train where each pulse has a width of 600 µs and a pulse period of 5 ms.

+

Alias the trigger timers to use for pulse width and period.

+

Create a fixed level voltage sweep.

+

Set the pulse width and trigger the pulse width timer with a period timer.

+

Set the pulse period to output one pulse per period and the count to generate 10 pulses.

+

Trigger the pulse period timer when a sweep is initiated.

+

Configure the timer to output a trigger event when it starts the first delay.

+

Trigger the SMU source action using pulse period timer.

+

Trigger the SMU end pulse action using pulse width timer.

+

Set the trigger model counts.

+

Configure the SMU to execute a 10-point pulse train.

+

Start the trigger model.

+

Wait for the sweep to complete.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15178.htm b/WebHelpDocs/2601B-PULSE/15178.htm new file mode 100644 index 0000000..17a50a4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15178.htm @@ -0,0 +1,99 @@ + + + + + smua.trigger.source.action + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.action

+

This attribute enables or disables sweeping the source (on or off).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.DISABLE)

+
+

Usage

+

action = smua.trigger.source.action

+

smua.trigger.source.action = action

+

+ + + + + + +

action

+

Sweep source action. Set to one of the following values:

+
  • 0 or smua.DISABLE: Do not sweep the source
  • 1 or smua.ENABLE: Sweep the source
+

Details

+

This attribute is used to enable or disable source level changes during a sweep. In addition to enabling the action before initiating the sweep, make sure to configure it using smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY().

+

Example

+

+ + + + + + + + +

smua.trigger.source.listv({3, 1, 4, 5, 2})

+

smua.trigger.source.action = smua.ENABLE

+

Configure list sweep (sweep through 3 V, 1 V, 4 V, 5 V, and 2 V).

+

Enable the source action.

+
+

Also see

+

smua.trigger.source.linearY()

+

smua.trigger.source.listY()

+

smua.trigger.source.logY()

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15179.htm b/WebHelpDocs/2601B-PULSE/15179.htm new file mode 100644 index 0000000..6ae8b02 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15179.htm @@ -0,0 +1,103 @@ + + + + + smua.trigger.source.limitY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.limitY

+

This attribute sets the sweep source limit.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.LIMIT_AUTO)

+
+

Usage

+

sweepSourceLimit = smua.trigger.source.limitY

+

smua.trigger.source.limitY = sweepSourceLimit

+

+ + + + + + + + + + +

sweepSourceLimit

+

The source limit that is used during triggered operation; set to:

+
  • A user-defined value
  • smua.LIMIT_AUTO

Y

+

SMU output function (v = voltage, i = current)

+
+

Details

+

Use this attribute to perform extended operating area (EOA) pulse mode sweeps.

+

If this attribute is set to smua.LIMIT_AUTO (or 0), the SMU uses the normal limit setting during sweeping. If this attribute is set to any other numeric value, the SMU switches in this limit at the start of the source action and returns to the normal limit setting at the end of the end pulse action.

+

Normally, the limit range is automatically adjusted in accordance with the limit value. During sweeping, however, the limit range is fixed to avoid the delays associated with changing range. This fixed limit range is determined by the maximum limit value needed during the sweep; that is, the greater of either the normal limit value (as specified by smua.source.limitY) or the sweep limit value (as specified by smua.trigger.source.limitY). Note that the minimum limit value that can be enforced during the sweep is equal to 10% of the full scale value of the fixed limit range. If the smaller limit value (normal or sweep) falls below this 10% threshold, the 10% value is enforced instead. Likewise, if the limit value falls below the 10% threshold as a result of power compliance, the 10% value is enforced instead.

+

When using the EOA, the SMU will automatically start the end pulse action if the SMU is not triggered before its maximum pulse width. It will also delay the source action if necessary to limit the pulse duty cycle to stay within the capabilities of the SMU.

+

Example

+

+ + + + + + +

smua.trigger.source.limitv = 10

+

Sets the voltage sweep limit to 10 V.

+
+

Also see

+

Configuring and running sweeps

+

smua.source.limitY

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15180.htm b/WebHelpDocs/2601B-PULSE/15180.htm new file mode 100644 index 0000000..5ed86c0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15180.htm @@ -0,0 +1,119 @@ + + + + + smua.trigger.source.linearY() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.linearY()

+

This function configures a linear source sweep.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.source.linearY(startValue, endValue, points)

+

+ + + + + + + + + + + + + + + + + + +

Y

+

SMU source function (v = voltage, i = current)

+

startValue

+

Source value of the first point

+

endValue

+

Source value of the last point

+

points

+

The number of points used to calculate the step size

+
+

Details

+

This function configures the source action to be a linear source sweep in a subsequent sweep. During the sweep, the source will generate a uniform series of ascending or descending voltage or current changes called steps. The number of source steps is one less than the number of sourced points.

+

The points parameter does not set the number of steps in a sweep, but rather is used to calculate source values within a subsequent sweep. If the subsequent sweep has more points than specified in points, the source will restart at the beginning. This means that if the trigger count is greater than the number of points in a sweep as configured, the SMU will satisfy the trigger count by restarting the sweep values from the beginning.

+

If the subsequent sweep has fewer points than specified in points, endValue will not be reached during the sweep. This means that if the trigger count is less than the number of source values configured, the SMU will satisfy the trigger count and ignore the remaining source values.

+

In cases where the first sweep point is a nonzero value, it may be necessary to pre-charge the circuit so that the sweep will return a stable value for the first measured point without penalizing remaining points in the sweep.

+

With linear sweeps, it is acceptable to maintain a fixed source resolution over the entire sweep. To prevent source range changes during the sweep (especially when sweeping through 0.0), set the source range to a fixed range appropriate for the larger of either startValue or endValue.

+

The SMU will only store the most recent configured source action. The last call to smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY() is used for the source action.

+

Source functions cannot be changed within a sweep.

+

After configuring the sweep source values, enable the source action by setting smua.trigger.source.action.

+

Example

+

+ + + + + + +

smua.trigger.source.linearv(0, 10, 11)

+

Sweeps from 0 V to 10 V in 1 V steps.

+
+

Also see

+

smua.trigger.source.action

+

smua.trigger.source.listY()

+

smua.trigger.source.logY()

+

Sweep Operation

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15181.htm b/WebHelpDocs/2601B-PULSE/15181.htm new file mode 100644 index 0000000..6da2bcd --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15181.htm @@ -0,0 +1,107 @@ + + + + + smua.trigger.source.listY() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.listY()

+

This function configures an array-based source sweep.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.source.listY(sweepList)

+

+ + + + + + + + + + +

Y

+

SMU source function (v = voltage, i = current)

+

sweepList

+

An array of source values

+
+

Details

+

This function configures the source action to be a list sweep in a subsequent sweep. During the sweep, the source will output the sequence of source values given in the sweepList array.

+

If the subsequent sweep has more points than specified in sweepList, the source will restart at the beginning. This means that if the trigger count is greater than the number of points in a sweep as configured, the SMU will satisfy the trigger count by restarting the sweep values from the beginning.

+

If the subsequent sweep has fewer points than specified in sweepList, the extra values will be ignored. This means that if the trigger count is less than the number of source values configured, the SMU will satisfy the trigger count and ignore the remaining source values.

+

In cases where the first sweep point is a nonzero value, it may be necessary to pre-charge the circuit so that the sweep will return a stable value for the first measured point without penalizing remaining points in the sweep.

+

The SMU will only store the most recent configured source action. The last call to smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY() is used for the source action.

+

Source functions cannot be changed within a sweep.

+

After configuring the sweep source values, enable the source action by setting smua.trigger.source.action.

+

Example

+

+ + + + + + +

smua.trigger.source.listv({3, 1, 4, 5, 2})

+

 

+

Sweeps through 3 V, 1 V, 4 V, 5 V, and 2 V.

+
+

Also see

+

smua.trigger.source.action

+

smua.trigger.source.linearY()

+

smua.trigger.source.logY()

+

Sweep Operation

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15182.htm b/WebHelpDocs/2601B-PULSE/15182.htm new file mode 100644 index 0000000..376bc04 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15182.htm @@ -0,0 +1,127 @@ + + + + + smua.trigger.source.logY() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.logY()

+

This function configures an exponential (geometric) source sweep.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.source.logY(startValue, endValue, points, asymptote)

+

+ + + + + + + + + + + + + + + + + + + + + + +

Y

+

SMU source function (v = voltage, i = current)

+

startValue

+

Source value of the first point

+

endValue

+

Source value of the last point

+

points

+

The number of points used to calculate the step size

+

asymptote

+

The asymptotic offset value

+
+

Details

+

This function configures the source action to be a geometric source sweep in a subsequent sweep. During the sweep, the source generates a geometric series of ascending or descending voltage or current changes called steps. Each step is larger or smaller than the previous step by a fixed proportion. The constant of proportionality is determined by the starting value, the ending value, the asymptote, and the number of steps in the sweep. The number of source steps is one less than the number of sourced points.

+

The points parameter does not set the number of steps in a sweep, but rather is used to calculate source values within a subsequent sweep. If the subsequent sweep has more points than specified in points, the source restarts at the beginning. This means that if the trigger count is greater than the number of points in a sweep as configured, the SMU satisfies the trigger count by restarting the sweep values from the beginning.

+

If the subsequent sweep has fewer points than specified in points, endValue is not reached during the sweep. This means that if the trigger count is less than the number of source values configured, the SMU satisfies the trigger count and ignores the remaining source values.

+

In cases where the first sweep point is nonzero, it may be necessary to pre-charge the circuit so that the sweep returns a stable value for the first measured point without penalizing remaining points in the sweep.

+

With logarithmic sweeps, it is usually necessary to allow the source to autorange to maintain good source accuracy when sweeping over more than one decade or across range boundaries.

+

The asymptote parameter can be used to customize the inflection and offset of the source value curve. This allows log sweeps to cross zero. Setting this parameter to zero provides a conventional logarithmic sweep. The asymptote value is the value that the curve has at either positive or negative infinity, depending on the direction of the sweep.

+

The asymptote value must not be equal to or between the starting and ending values. It must be outside the range defined by the starting and ending values.

+

The SMU stores only the most recent configured source action. The last call to smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY() is used for the source action.

+

Source functions cannot be changed within a sweep.

+

After configuring the sweep source values, enable the source action by setting smua.trigger.source.action.

+

Example

+

+ + + + + + +

smua.trigger.source.logv(1, 10, 11, 0)

+

Sweeps from 1 V to 10 V in 10 steps with an asymptote of 0 V.

+
+

Also see

+

smua.trigger.source.action

+

smua.trigger.source.linearY()

+

smua.trigger.source.listY()

+

Sweep operation

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15183.htm b/WebHelpDocs/2601B-PULSE/15183.htm new file mode 100644 index 0000000..56087dc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15183.htm @@ -0,0 +1,97 @@ + + + + + smua.trigger.source.set() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.set()

+

This function sets the source event detector to the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.trigger.source.set()

+

Details

+

This function sets the source event detector to the detected state.

+

The SMU automatically clears all event detectors when the smua.trigger.initiate() function is executed. This function should be called after the sweep is initiated. If the event detectors are configured to clear automatically because the smua.trigger.autoclear attribute is set to smua.ENABLE, make sure that smua.trigger.source.set() is issued after the SMU has entered the trigger layer.

+

Example

+

+ + + + + + + + +

reset()

+

smua.trigger.source.listv({5})

+

smua.trigger.source.stimulus = display.trigger.EVENT_ID

+

smua.source.output = smua.OUTPUT_ON

+

smua.trigger.initiate()

+

delay(1)

+

-- Continue even if the display trigger key was not pressed.

+

smua.trigger.source.set()

+

waitcomplete()

+

Sets the source event detector.

+
+

Also see

+

smua.trigger.arm.set()

+

smua.trigger.autoclear

+

smua.trigger.endpulse.set()

+

smua.trigger.initiate()

+

smua.trigger.measure.set()

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15184.htm b/WebHelpDocs/2601B-PULSE/15184.htm new file mode 100644 index 0000000..dc10177 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15184.htm @@ -0,0 +1,204 @@ + + + + + smua.trigger.source.stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.stimulus

+

This attribute defines which event causes the source event detector to enter the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0

+
+

Usage

+

eventID = smua.trigger.source.stimulus

+

smua.trigger.source.stimulus = eventID

+

+ + + + + + +

eventID

+

Set to the event that triggers the end-pulse source off action

+
+

Details

+

Set this attribute to the event ID of any trigger event generator to wait for that event. When set, the SMU waits for the event at the source event detector portion of the trigger model. To bypass waiting for an event, set the value of this attribute to zero (0). Set eventID to one of the existing trigger event IDs shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Example

+

+ + + + + + + + +

smua.trigger.source.stimulus = digio.trigger[2].EVENT_ID

+

Configure to start its source action when a trigger event occurs on digital I/O line 2.

+
+

Also see

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15280.htm b/WebHelpDocs/2601B-PULSE/15280.htm new file mode 100644 index 0000000..919bd45 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15280.htm @@ -0,0 +1,113 @@ + + + + + tspnet.tsp.runscript() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tspnet.tsp.runscript()

+

This function loads and runs a script on a remote TSP-enabled instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

tspnet.tsp.runscript(connectionID, "script")

+

tspnet.tsp.runscript(connectionID, "name", "script")

+

+ + + + + + + + + + + + + + +

connectionID

+

Integer value used as an identifier for other tspnet commands

+

name

+

The name that is assigned to the script

+

script

+

The body of the script as a string

+
+

Details

+

This function is appropriate only for TSP-enabled instruments.

+

This function downloads a script to a remote instrument and runs it. It automatically adds the appropriate loadscript and endscript commands around the script, captures any errors, and reads back any prompts. No additional substitutions are done on the text.

+

The script is automatically loaded, compiled, and run.

+

Any output from previous commands is discarded.

+

This command does not wait for the script to complete.

+

If you do not want the script to do anything immediately, make sure the script only defines functions for later use. Use the tspnet.execute() function to execute those functions later.

+

If no name is specified, the script is loaded as the anonymous script.

+

Example

+

+ + + + + + + + +

tspnet.tsp.runscript(myconnection, "mytest",

+

"print([[start]]) for d = 1, 10 do print([[work]]) end print([[end]])")

+

Load and run a script entitled mytest on the TSP-enabled instrument connected with myconnection.

+
+

Also see

+

tspnet.execute()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15281.htm b/WebHelpDocs/2601B-PULSE/15281.htm new file mode 100644 index 0000000..fe8a589 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15281.htm @@ -0,0 +1,120 @@ + + + + + timer.measure.t() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

timer.measure.t()

+

This function measures the elapsed time since the timer was last reset.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

time = timer.measure.t()

+

+ + + + + + +

time

+

The elapsed time in seconds (1 µs resolution)

+
+

Example 1

+

+ + + + + + +

timer.reset()

+

-- (intervening code)

+

time = timer.measure.t()

+

print(time)

+

This example resets the timer and measures the time since the reset.

+

Output:

+

1.469077e+01

+

The output will vary. The above output indicates that timer.measure.t() was executed 14.69077 seconds after timer.reset().

+
+

Example 2

+

+ + + + + + +

beeper.enable = beeper.ON

+

beeper.beep(0.5, 2400)

+

print("reset timer")

+

timer.reset()

+

delay(0.5)

+

dt = timer.measure.t()

+

print("timer after delay:", dt)

+

beeper.beep(0.5, 2400)

+

Enable the beeper.

+

Emit a beep and set the beeper.

+

Reset the timer.

+

Set a delay.

+

Verify the duration of the delay before emitting another beep.

+

Output:

+

reset timer

+

timer after delay: 5.00e-01

+
+

Also see

+

timer.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15282.htm b/WebHelpDocs/2601B-PULSE/15282.htm new file mode 100644 index 0000000..ecf69ce --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15282.htm @@ -0,0 +1,85 @@ + + + + + timer.reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

timer.reset()

+

This function resets the timer to zero (0) seconds.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

timer.reset()

+

Example

+

+ + + + + + +

timer.reset()

+

-- (intervening code)

+

time = timer.measure.t()

+

print(time)

+

Resets the timer and then measures the time since the reset.

+

Output:

+

1.469077e+01

+

The above output indicates that timer.measure.t() was executed 14.69077 seconds after timer.reset().

+
+

Also see

+

timer.measure.t()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15285.htm b/WebHelpDocs/2601B-PULSE/15285.htm new file mode 100644 index 0000000..43f3c12 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15285.htm @@ -0,0 +1,94 @@ + + + + + tsplink.group + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.group

+

This attribute contains the group number of a TSP-Link node.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Power cycle

+

Not applicable

+

0

+
+

Usage

+

groupNumber = tsplink.group

+

tsplink.group = groupNumber

+

+ + + + + + +

groupNumber

+

The group number of the TSP-Link node (0 to 64)

+
+

Details

+

To remove the node from all groups, set the attribute value to 0.

+

When the node is turned off, the group number for that node changes to 0.

+

The master node can be assigned to any group. You can also include other nodes in the group that includes the master. Note that any nodes that are set to 0 are automatically included in the group that contains the master node, regardless of the group that is assigned to the master node.

+

Example

+

+ + + + + + +

tsplink.group = 3

+

Assign the instrument to TSP-Link group number 3.

+
+

Also see

+

Using groups to manage nodes on a TSP-Link system

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15286.htm b/WebHelpDocs/2601B-PULSE/15286.htm new file mode 100644 index 0000000..9bb5e7d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15286.htm @@ -0,0 +1,91 @@ + + + + + tsplink.master + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.master

+

This attribute reads the node number assigned to the master node.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

masterNodeNumber = tsplink.master

+

+ + + + + + +

masterNodeNumber

+

The node number of the master node

+
+

Details

+

After doing a TSP-Link reset (tsplink.reset()), use this attribute to access the node number of the master in a set of instruments connected over TSP-Link.

+

Example

+

+ + + + + + +

LinkMaster = tsplink.master

+

Store the TSP-Link master node number in a variable called LinkMaster.

+
+

Also see

+

tsplink.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15287.htm b/WebHelpDocs/2601B-PULSE/15287.htm new file mode 100644 index 0000000..eeed496 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15287.htm @@ -0,0 +1,95 @@ + + + + + tsplink.node + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.node

+

This attribute defines the node number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

1

+
+

Usage

+

nodeNumber = tsplink.node

+

tsplink.node = nodeNumber

+

+ + + + + + +

nodeNumber

+

The node number of the instrument or enclosure (1 to 64 )

+
+

Details

+

This command sets the TSP-Link node number and saves the value in nonvolatile memory.

+

Changes to the node number do not take effect until tsplink.reset() from an earlier TSP-Link instrument is executed on any node in the system.

+

Each node connected to the TSP-Link system must be assigned a different node number.

+

Example

+

+ + + + + + +

tsplink.node = 3

+

Sets the TSP-Link node for this instrument to number 3.

+
+

Also see

+

tsplink.reset()

+

tsplink.state

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15288.htm b/WebHelpDocs/2601B-PULSE/15288.htm new file mode 100644 index 0000000..abe1dbe --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15288.htm @@ -0,0 +1,101 @@ + + + + + tsplink.readbit() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.readbit()

+

This function reads the state of a TSP-Link synchronization line.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

data = tsplink.readbit(N)

+

+ + + + + + + + + + +

data

+

The state of the synchronization line

+

N

+

The trigger line (1 to 3)

+
+

Details

+

Returns a value of zero (0) if the line is low and 1 if the line is high.

+

Example

+

+ + + + + + +

data = tsplink.readbit(3)

+

print(data)

+

Assume line 3 is set high, and it is then read.

+

Output:

+

1.000000e+00

+
+

Also see

+

tsplink.readport()

+

tsplink.writebit()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15289.htm b/WebHelpDocs/2601B-PULSE/15289.htm new file mode 100644 index 0000000..3d98348 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15289.htm @@ -0,0 +1,99 @@ + + + + + tsplink.readport() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.readport()

+

This function reads the TSP-Link trigger lines as a digital I/O port.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

data = tsplink.readport()

+

+ + + + + + +

data

+

Numeric value that indicates which lines are set

+
+

Details

+

The binary equivalent of the returned value indicates the input pattern on the I/O port. The least significant bit of the binary number corresponds to line 1 and the value of bit 3 corresponds to line 3. For example, a returned value of 2 has a binary equivalent of 010. This indicates that line 2 is high (1), and that the other two lines are low (0).

+

Example

+

+ + + + + + +

data = tsplink.readport()

+

print(data)

+

Reads state of all three TSP-Link lines.

+

Assuming line 2 is set high, the output is:

+

2.000000e+00

+

(binary 010)

+

The format of the output may vary depending on the ASCII precision setting.

+
+

Also see

+

TSP-Link trigger lines

+

tsplink.readbit()

+

tsplink.writebit()

+

tsplink.writeport()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15290.htm b/WebHelpDocs/2601B-PULSE/15290.htm new file mode 100644 index 0000000..2565851 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15290.htm @@ -0,0 +1,106 @@ + + + + + tsplink.reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.reset()

+

This function initializes (resets) all nodes (instruments) in the TSP-Link system.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

nodesFound = tsplink.reset()

+

nodesFound = tsplink.reset(expectedNodes)

+

+ + + + + + + + + + +

nodesFound

+

The number of nodes actually found on the system

+

expectedNodes

+

The number of nodes expected on the system (1 to 64)

+
+

Details

+

This function erases all information regarding other nodes connected on the TSP-Link system and regenerates the system configuration. This function must be called at least once before any remote nodes can be accessed. If the node number for any instrument is changed, the TSP-Link must be reset again.

+

If expectedNodes is not given, this function generates an error if no other nodes are found on the TSP-Link network.

+

If nodesFound is less than expectedNodes, an error is generated. Note that the node on which the command is running is counted as a node. For example, giving an expected node count of 1 will not generate any errors, even if there are no other nodes on the TSP-Link network.

+

Also returns the number of nodes found.

+

Example

+

+ + + + + + +

nodesFound = tsplink.reset(2)

+

print("Nodes found = " .. nodesFound)

+

Perform a TSP-Link reset and indicate how many nodes are found.

+

Sample output if two nodes are found:
Nodes found = 2

+

Sample output if fewer nodes are found and if localnode.showerrors = 1:
1219, TSP-Link found fewer nodes
than expected
Nodes found = 1

+
+

Also see

+

localnode.showerrors

+

tsplink.node

+

tsplink.state

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15291.htm b/WebHelpDocs/2601B-PULSE/15291.htm new file mode 100644 index 0000000..95347de --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15291.htm @@ -0,0 +1,94 @@ + + + + + tsplink.state + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.state

+

This attribute describes the TSP-Link online state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

state = tsplink.state

+

+ + + + + + +

state

+

TSP-Link state (online or offline)

+
+

Details

+

When the instrument power is first turned on, the state is offline. After tsplink.reset() is successful, the state is online.

+

Example

+

+ + + + + + +

state = tsplink.state

+

print(state)

+

Read the state of the TSP-Link system. If it is online, the output is:

+

online

+
+

Also see

+

tsplink.node

+

tsplink.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15292.htm b/WebHelpDocs/2601B-PULSE/15292.htm new file mode 100644 index 0000000..b34b9c4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15292.htm @@ -0,0 +1,97 @@ + + + + + tsplink.trigger[N].assert() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].assert()

+

This function simulates the occurrence of the trigger and generates the corresponding event ID.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

tsplink.trigger[N].assert()

+

+ + + + + + +

N

+

The trigger line (1 to 3)

+
+

Details

+

The set pulse width determines how long the trigger is asserted.

+

Example

+

+ + + + + + +

tsplink.trigger[2].assert()

+

Asserts trigger on trigger line 2.

+
+

Also see

+

tsplink.trigger[N].clear()

+

tsplink.trigger[N].mode

+

tsplink.trigger[N].overrun

+

tsplink.trigger[N].pulsewidth

+

tsplink.trigger[N].release()

+

tsplink.trigger[N].stimulus

+

tsplink.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15293.htm b/WebHelpDocs/2601B-PULSE/15293.htm new file mode 100644 index 0000000..140a960 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15293.htm @@ -0,0 +1,95 @@ + + + + + tsplink.trigger[N].clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].clear()

+

This function clears the event detector for a LAN trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

tsplink.trigger[N].clear()

+

+ + + + + + +

N

+

The trigger line (1 to 3) to clear

+
+

Details

+

The trigger event detector enters the detected state when an event is detected. tsplink.trigger[N].clear() clears a trigger event detector, discards the history of the trigger line, and clears the tsplink.trigger[N].overrun attribute.

+

Example

+

+ + + + + + +

tsplink.trigger[2].clear()

+

Clears trigger event on synchronization line 2.

+
+

Also see

+

tsplink.trigger[N].mode

+

tsplink.trigger[N].overrun

+

tsplink.trigger[N].release()

+

tsplink.trigger[N].stimulus

+

tsplink.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15294.htm b/WebHelpDocs/2601B-PULSE/15294.htm new file mode 100644 index 0000000..d11f9f5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15294.htm @@ -0,0 +1,98 @@ + + + + + tsplink.trigger[N].EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].EVENT_ID

+

This constant identifies the number that is used for the trigger events.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = tsplink.trigger[N].EVENT_ID

+

+ + + + + + + + + + +

eventID

+

The trigger event number

+

N

+

The trigger line (1 to 3)

+
+

Details

+

This number is used by the TSP-Link trigger line when it detects an input trigger.

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to trigger events from this line.

+

Example

+

+ + + + + + +

trigger.timer[1].stimulus = tsplink.trigger[2].EVENT_ID

+

Sets the trigger stimulus of trigger timer 1 to the TSP-Link trigger 2 event.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15295.htm b/WebHelpDocs/2601B-PULSE/15295.htm new file mode 100644 index 0000000..8c1fe15 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15295.htm @@ -0,0 +1,198 @@ + + + + + tsplink.trigger[N].mode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].mode

+

This attribute defines the trigger operation and detection mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup
TSP-Link trigger N reset

+

Not saved

+

0 (tsplink.TRIG_BYPASS)

+
+

Usage

+

mode = tsplink.trigger[N].mode

+

tsplink.trigger[N].mode = mode

+

+ + + + + + + + + + +

mode

+

The trigger mode

+

N

+

The trigger line (1 to 3)

+
+

Details

+

This attribute controls the mode in which the trigger event detector and the output trigger generator operate on the given trigger line.

+

The setting for mode can be one of the following values:

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Mode

+

Number value

+

Description

+

tsplink.TRIG_BYPASS

+

0

+

Allows direct control of the line as a digital I/O line.

+

tsplink.TRIG_FALLING

+

1

+

Detects falling-edge triggers as input. Asserts a TTL-low pulse for output.

+

tsplink.TRIG_RISING

+

2

+

If the programmed state of the line is high, the tsplink.TRIG_RISING mode behaves similarly to tsplink.TRIG_RISINGA.

+

If the programmed state of the line is low, the tsplink.TRIG_RISING mode behaves similarly to tsplink.TRIG_RISINGM.

+

Use tsplink.TRIG_RISINGA if the line is in the high output state.

+

Use tsplink.TRIG_RISINGM if the line is in the low output state.

+

tsplink.TRIG_EITHER

+

3

+

Detects rising- or falling-edge triggers as input. Asserts a TTL-low pulse for output.

+

tsplink.TRIG_SYNCHRONOUSA

+

4

+

Detects the falling-edge input triggers and automatically latches and drives the trigger line low.

+

tsplink.TRIG_SYNCHRONOUS

+

5

+

Detects the falling-edge input triggers and automatically latches and drives the trigger line low. Asserts a TTL-low pulse as an output trigger.

+

tsplink.TRIG_SYNCHRONOUSM

+

6

+

Detects rising-edge triggers as an input. Asserts a TTL-low pulse for output.

+

tsplink.TRIG_RISINGA

+

7

+

Detects rising-edge triggers as input. Asserts a TTL-low pulse for output.

+

tsplink.TRIG_RISINGM

+

8

+

Edge detection as an input is not available. Generates a TTL-high pulse as an output trigger.

+
+

When programmed to any mode except tsplink.TRIG_BYPASS, the output state of the I/O line is controlled by the trigger logic, and the user-specified output state of the line is ignored.

+

When the trigger mode is set to tsplink.TRIG_RISING, the user-specified output state of the line is examined. If the output state selected when the mode is changed is high, the actual mode used will be tsplink.TRIG_RISINGA. If the output state selected when the mode is changed is low, the actual mode used will be tsplink.TRIG_RISINGM.

+

mode stores the trigger mode as a numeric value when the attribute is read.

+

To control the line state, use the tsplink.TRIG_BYPASS mode with the tsplink.writebit() and the tsplink.writeport() commands.

+

Example

+

+ + + + + + +

tsplink.trigger[3].mode = tsplink.TRIG_RISINGM

+

Sets the trigger mode for synchronization line 3 to tsplink.TRIG_RISINGM.

+
+

Also see

+

digio.writebit()

+

digio.writeport()

+

tsplink.trigger[N].assert()

+

tsplink.trigger[N].clear()

+

tsplink.trigger[N].overrun

+

tsplink.trigger[N].release()

+

tsplink.trigger[N].reset()

+

tsplink.trigger[N].stimulus

+

tsplink.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15296.htm b/WebHelpDocs/2601B-PULSE/15296.htm new file mode 100644 index 0000000..bed3e1a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15296.htm @@ -0,0 +1,105 @@ + + + + + tsplink.trigger[N].overrun + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].overrun

+

This attribute indicates if the event detector ignored an event while in the detected state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Instrument reset
Recall setup
TSP-Link trigger N clear
TSP-Link trigger N reset

+

Not applicable

+

Not applicable

+
+

Usage

+

overrun = tsplink.trigger[N].overrun

+

+ + + + + + + + + + +

overrun

+

Trigger overrun state

+

N

+

The trigger line (1 to 3)

+
+

Details

+

This command indicates whether an event has been ignored because the event detector was already in the detected state when the event occurred.

+

This is an indication of the state of the event detector built into the synchronization line itself.

+

It does not indicate if an overrun occurred in any other part of the trigger model, or in any other construct that is monitoring the event. It also is not an indication of an output trigger overrun. Output trigger overrun indications are provided in the status model.

+

Example

+

+ + + + + + +

print(tsplink.trigger[1].overrun)

+

If an event was ignored, displays true; if an event was not ignored, displays false.

+
+

Also see

+

tsplink.trigger[N].assert()

+

tsplink.trigger[N].clear()

+

tsplink.trigger[N].mode

+

tsplink.trigger[N].release()

+

tsplink.trigger[N].reset()

+

tsplink.trigger[N].stimulus

+

tsplink.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15297.htm b/WebHelpDocs/2601B-PULSE/15297.htm new file mode 100644 index 0000000..6158f37 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15297.htm @@ -0,0 +1,98 @@ + + + + + tsplink.trigger[N].pulsewidth + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].pulsewidth

+

This attribute sets the length of time that the trigger line is asserted for output triggers.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
TSP-Link trigger N reset
Recall setup

+

Not saved

+

10e-6 (10 µs)

+
+

Usage

+

width = tsplink.trigger[N].pulsewidth

+

tsplink.trigger[N].pulsewidth = width

+

+ + + + + + + + + + +

width

+

The pulse width (in seconds)

+

N

+

The trigger line (1 to 3)

+
+

Details

+

Setting the pulse width to 0 (seconds) asserts the trigger indefinitely.

+

Example

+

+ + + + + + +

tsplink.trigger[3].pulsewidth = 20e-6

+

Sets pulse width for trigger line 3 to 20 μs.

+
+

Also see

+

tsplink.trigger[N].release()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15298.htm b/WebHelpDocs/2601B-PULSE/15298.htm new file mode 100644 index 0000000..c549ced --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15298.htm @@ -0,0 +1,97 @@ + + + + + tsplink.trigger[N].release() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].release()

+

This function releases a latched trigger on the given TSP-Link trigger line.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

tsplink.trigger[N].release()

+

+ + + + + + +

N

+

The trigger line (1 to 3)

+
+

Details

+

Releases a trigger that was asserted with an indefinite pulse width. It also releases a trigger that was latched in response to receiving a synchronous mode trigger.

+

Example

+

+ + + + + + +

tsplink.trigger[3].release()

+

Releases trigger line 3.

+
+

Also see

+

tsplink.trigger[N].assert()

+

tsplink.trigger[N].clear()

+

tsplink.trigger[N].mode

+

tsplink.trigger[N].overrun

+

tsplink.trigger[N].pulsewidth

+

tsplink.trigger[N].stimulus

+

tsplink.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15300.htm b/WebHelpDocs/2601B-PULSE/15300.htm new file mode 100644 index 0000000..e9930a5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15300.htm @@ -0,0 +1,109 @@ + + + + + tsplink.trigger[N].wait() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].wait()

+

This function waits for a trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

triggered = tsplink.trigger[N].wait(timeout)

+

+ + + + + + + + + + + + + + +

triggered

+

Trigger detection indication; set to one of the following values:

+

true: A trigger is detected during the timeout period

+

false: A trigger is not detected during the timeout period

+

N

+

The trigger line (1 to 3)

+

timeout

+

The timeout value in seconds

+
+

Details

+

This function waits up to the timeout value for an input trigger. If one or more trigger events were detected since the last time tsplink.trigger[N].wait() or tsplink.trigger[N].clear() was called, this function returns immediately.

+

After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.

+

Example

+

+ + + + + + +

triggered = tsplink.trigger[3].wait(10)

+

print(triggered)

+

Waits up to 10 seconds for a trigger on TSP-Link® line 3.

+

If false is returned, no trigger was detected during the 10-second timeout.

+

If true is returned, a trigger was detected.

+
+

Also see

+

tsplink.trigger[N].clear()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15301.htm b/WebHelpDocs/2601B-PULSE/15301.htm new file mode 100644 index 0000000..2404b7a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15301.htm @@ -0,0 +1,102 @@ + + + + + tsplink.writebit() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.writebit()

+

This function sets a TSP-Link trigger line high or low.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

tsplink.writebit(N, data)

+

+ + + + + + + + + + +

N

+

The trigger line (1 to 3)

+

data

+

The value to write to the bit:

+
  • Low: 0
  • High: 1
+

Details

+

Use tsplink.writebit() and tsplink.writeport() to control the output state of the trigger line when trigger operation is set to tsplink.TRIG_BYPASS.

+

If the output line is write-protected by the tsplink.writeprotect attribute, this command is ignored.

+

The reset function does not affect the present states of the TSP-Link trigger lines.

+

Example

+

+ + + + + + +

tsplink.writebit(3, 0)

+

Sets trigger line 3 low (0).

+
+

Also see

+

tsplink.readbit()

+

tsplink.readport()

+

tsplink.writeport()

+

tsplink.writeprotect

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15302.htm b/WebHelpDocs/2601B-PULSE/15302.htm new file mode 100644 index 0000000..f9ed2a9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15302.htm @@ -0,0 +1,97 @@ + + + + + tsplink.writeport() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.writeport()

+

This function writes to all TSP-Link synchronization lines.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

tsplink.writeport(data)

+

+ + + + + + +

data

+

Value to write to the port (0 to 7)

+
+

Details

+

The binary representation of data indicates the output pattern that is written to the I/O port. For example, a data value of 2 has a binary equivalent of 010. Line 2 is set high (1), and the other two lines are set low (0).

+

Write-protected lines are not changed.

+

Use the tsplink.writebit() and tsplink.writeport() commands to control the output state of the synchronization line when trigger operation is set to tsplink.TRIG_BYPASS.

+

The reset() function does not affect the present states of the trigger lines.

+

Example

+

+ + + + + + +

tsplink.writeport(3)

+

Sets the synchronization lines 1 and 2 high (binary 011).

+
+

Also see

+

tsplink.readbit()

+

tsplink.readport()

+

tsplink.writebit()

+

tsplink.writeprotect

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15424.htm b/WebHelpDocs/2601B-PULSE/15424.htm new file mode 100644 index 0000000..bcc0cc1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15424.htm @@ -0,0 +1,45 @@ + + + + + Output-off states + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Output-off states

+

+

VARIABLE - CAUTION
Carefully consider and configure the appropriate output-off state, source, and compliance limits before connecting the 2601B-PULSE to a device that can deliver energy (for example, other voltage sources, batteries, capacitors, solar cells, or other 2601B-PULSE instruments). Configure recommended instrument settings before making connections to the device. Failure to consider the output-off state, source, and compliance limits may result in damage to the instrument or to the device under test (DUT).

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15785.htm b/WebHelpDocs/2601B-PULSE/15785.htm new file mode 100644 index 0000000..8c3d748 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15785.htm @@ -0,0 +1,91 @@ + + + + + trigger.blender[N].clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.blender[N].clear()

+

This function clears the blender event detector and resets the overrun indicator of blender N.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

trigger.blender[N].clear()

+

+ + + + + + +

N

+

The blender number (up to six)

+
+

Details

+

This command sets the blender event detector to the undetected state and resets the overrun indicator of the event detector.

+

Example

+

+ + + + + + +

trigger.blender[2].clear()

+

Clears the event detector for blender 2.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15786.htm b/WebHelpDocs/2601B-PULSE/15786.htm new file mode 100644 index 0000000..5c0f739 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15786.htm @@ -0,0 +1,99 @@ + + + + + trigger.blender[N].EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.blender[N].EVENT_ID

+

This constant contains the trigger blender event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = trigger.blender[N].EVENT_ID

+

+ + + + + + + + + + +

eventID

+

Trigger event number

+

N

+

The blender number (up to six)

+
+

Details

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to trigger events from this trigger blender.

+

Example

+

+ + + + + + + + +

digio.trigger[1].stimulus = trigger.blender[2].EVENT_ID

+

Set the trigger stimulus of digital I/O trigger 1 to be controlled by the trigger blender 2 event.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15787.htm b/WebHelpDocs/2601B-PULSE/15787.htm new file mode 100644 index 0000000..d5c7be3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15787.htm @@ -0,0 +1,101 @@ + + + + + trigger.blender[N].orenable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.blender[N].orenable

+

This attribute selects whether the blender performs OR operations or AND operations.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Trigger blender N reset
Recall setup

+

Not saved

+

false (AND mode)

+
+

Usage

+

orenable = trigger.blender[N].orenable

+

trigger.blender[N].orenable = orenable

+

+ + + + + + + + + + +

orenable

+

The type of operation:

+
  • true: OR operation
  • false: AND operation

N

+

The blender number (up to six)

+
+

Details

+

This command selects whether the blender waits for any one event (OR) or waits for all selected events (AND) before signaling an output event.

+

Example

+

+

+ + + + + + +

trigger.blender[1].orenable = true

+

trigger.blender[1].stimulus[1] = digio.trigger[3].EVENT_ID

+

trigger.blender[1].stimulus[2] = digio.trigger[5].EVENT_ID

+

Generate a trigger blender 1 event when a digital I/O trigger happens on line 3 or 5.

+
+

Also see

+

trigger.blender[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15788.htm b/WebHelpDocs/2601B-PULSE/15788.htm new file mode 100644 index 0000000..2fb6951 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15788.htm @@ -0,0 +1,99 @@ + + + + + trigger.blender[N].overrun + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.blender[N].overrun

+

This attribute indicates whether or not an event was ignored because of the event detector state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Instrument reset
Trigger blender N clear
Trigger blender N reset

+

Not applicable

+

Not applicable

+
+

Usage

+

overrun = trigger.blender[N].overrun

+

+ + + + + + + + + + +

overrun

+

Trigger blender overrun state (true or false)

+

N

+

The blender number (up to six)

+
+

Details

+

Indicates if an event was ignored because the event detector was already in the detected state when the event occurred. This is an indication of the state of the event detector that is built into the event blender itself.

+

This command does not indicate if an overrun occurred in any other part of the trigger model or in any other trigger object that is monitoring the event. It also is not an indication of an action overrun.

+

Example

+

+ + + + + + +

print(trigger.blender[1].overrun)

+

If an event was ignored, the output is true.

+

If an event was not ignored, the output is false.

+
+

Also see

+

trigger.blender[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15790.htm b/WebHelpDocs/2601B-PULSE/15790.htm new file mode 100644 index 0000000..f8f9b57 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15790.htm @@ -0,0 +1,116 @@ + + + + + trigger.blender[N].wait() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.blender[N].wait()

+

This function waits for a blender trigger event to occur.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

triggered = trigger.blender[N].wait(timeout)

+

+ + + + + + + + + + + + + + +

triggered

+

Trigger detection indication for blender

+

N

+

The trigger blender (up to six) on which to wait

+

timeout

+

Maximum amount of time in seconds to wait for the trigger blender event

+
+

Details

+

This function waits for an event blender trigger event. If one or more trigger events were detected since the last time trigger.blender[N].wait() or trigger.blender[N].clear() was called, this function returns immediately.

+

After detecting a trigger with this function, the event detector automatically resets and rearms. This is true regardless of the number of events detected.

+

Example

+

+ + + + + + + + +

digio.trigger[3].mode = digio.TRIG_FALLING

+

digio.trigger[5].mode = digio.TRIG_FALLING

+

trigger.blender[1].orenable = true

+

trigger.blender[1].stimulus[1] = digio.trigger[3].EVENT_ID

+

trigger.blender[1].stimulus[2] = digio.trigger[5].EVENT_ID

+

 

+

print(trigger.blender[1].wait(3))

+

Generate a trigger blender 1 event when a digital I/O trigger happens either on line 3 or 5.

+

 

+

Wait three seconds while checking if trigger blender 1 event has occurred.

+

 

+

If the blender trigger event has happened, then true is output. If the trigger event has not happened, then false is output after the timeout expires.

+
+

Also see

+

trigger.blender[N].clear()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15791.htm b/WebHelpDocs/2601B-PULSE/15791.htm new file mode 100644 index 0000000..1bb0812 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15791.htm @@ -0,0 +1,70 @@ + + + + + trigger.clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.clear()

+

This function clears the command interface trigger event detector.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

trigger.clear()

+

Details

+

The trigger event detector indicates if a trigger event has been detected since the last trigger.wait() call. trigger.clear() clears the trigger event detector and discards the history of command interface trigger events.

+

Also see

+

trigger.wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15792.htm b/WebHelpDocs/2601B-PULSE/15792.htm new file mode 100644 index 0000000..39aa2af --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15792.htm @@ -0,0 +1,91 @@ + + + + + trigger.EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.EVENT_ID

+

This constant contains the command interface trigger event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = trigger.EVENT_ID

+

+ + + + + + +

eventID

+

The event ID for the command interface triggers

+
+

Details

+

You can set the stimulus of any trigger object to the value of this constant to have the trigger object respond to command interface trigger events.

+

Example

+

+ + + + + + +

trigger.timer[1].stimulus = trigger.EVENT_ID

+

Sets the trigger stimulus of trigger timer 1 to the command interface trigger event.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15793.htm b/WebHelpDocs/2601B-PULSE/15793.htm new file mode 100644 index 0000000..0df1008 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15793.htm @@ -0,0 +1,91 @@ + + + + + trigger.timer[N].clear() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].clear()

+

This function clears the timer event detector and overrun indicator for the specified trigger timer number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

trigger.timer[N].clear()

+

+ + + + + + +

N

+

Trigger timer number (1 to 8)

+
+

Details

+

This command sets the timer event detector to the undetected state and resets the overrun indicator.

+

Example

+

+ + + + + + +

trigger.timer[1].clear()

+

Clears trigger timer 1.

+
+

Also see

+

trigger.timer[N].count

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15794.htm b/WebHelpDocs/2601B-PULSE/15794.htm new file mode 100644 index 0000000..757a051 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15794.htm @@ -0,0 +1,102 @@ + + + + + trigger.timer[N].delay + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].delay

+

This attribute sets and reads the timer delay.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup
Trigger timer N reset

+

Not saved

+

10e-6 (10 µs)

+
+

Usage

+

interval = trigger.timer[N].delay

+

trigger.timer[N].delay = interval

+

+ + + + + + + + + + +

interval

+

Delay interval in seconds (0.5 µs to 100 ks)

+

N

+

Trigger timer number (1 to 8)

+
+

Details

+

Once the timer is enabled, each time the timer is triggered, it uses this delay period.

+

Assigning a value to this attribute is equivalent to:

+

trigger.timer[N].delaylist = {interval}

+

This creates a delay list of one value.

+

Reading this attribute returns the delay interval that will be used the next time the timer is triggered.

+

Example

+

+ + + + + + +

trigger.timer[1].delay = 50e-6

+

Set the trigger timer 1 to delay for 50 µs.

+
+

Also see

+

trigger.timer[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15795.htm b/WebHelpDocs/2601B-PULSE/15795.htm new file mode 100644 index 0000000..5a92a7f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15795.htm @@ -0,0 +1,114 @@ + + + + + trigger.timer[N].delaylist + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].delaylist

+

This attribute sets an array of timer intervals.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup
Trigger timer N reset

+

Not saved

+

10e-6 (10 µs)

+
+

Usage

+

intervals = trigger.timer[N].delaylist

+

trigger.timer[N].delaylist = intervals

+

+ + + + + + + + + + +

intervals

+

Table of delay intervals in seconds

+

N

+

Trigger timer number (1 to 8)

+
+

Details

+

Each time the timer is triggered after it is enabled, it uses the next delay period from the array. The default value is an array with one value of 10 µs.

+

After all elements in the array have been used, the delays restart at the beginning of the list.

+

If the array contains more than one element, the average of the delay intervals in the list must be >= 50 µs.

+

Example

+

+ + + + + + + + +

trigger.timer[3].delaylist = {50e-6, 100e-6, 150e-6}

+

 

+

DelayList = trigger.timer[3].delaylist

+

for x = 1, table.getn(DelayList) do

+

print(DelayList[x])

+

end

+

Set a delay list on trigger timer 3 with three delays (50 µs, 100 µs, and 150 µs).

+

 

+

Read the delay list on trigger timer 3.

+

 

+

Output:

+

5e-05

+

0.0001

+

0.00015

+
+

Also see

+

trigger.timer[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15796.htm b/WebHelpDocs/2601B-PULSE/15796.htm new file mode 100644 index 0000000..c7f1b1e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15796.htm @@ -0,0 +1,98 @@ + + + + + trigger.timer[N].EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].EVENT_ID

+

This constant specifies the trigger timer event number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = trigger.timer[N].EVENT_ID

+

+ + + + + + + + + + +

eventID

+

The trigger event number

+

N

+

Trigger timer number (1 to 8)

+
+

Details

+

This constant is an identification number that identifies events generated by this timer.

+

Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to events from this timer.

+

Example

+

+ + + + + + +

trigger.timer[1].stimulus = tsplink.trigger[2].EVENT_ID

+

Sets the trigger stimulus of trigger timer 1 to the TSP-Link trigger 2 event.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15797.htm b/WebHelpDocs/2601B-PULSE/15797.htm new file mode 100644 index 0000000..7f5281f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15797.htm @@ -0,0 +1,100 @@ + + + + + trigger.timer[N].overrun + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].overrun

+

This attribute indicates if an event was ignored because of the event detector state.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Instrument reset
Recall setup
Trigger timer N clear
Trigger timer N reset

+

Not applicable

+

false

+
+

Usage

+

overrun = trigger.timer[N].overrun

+

+ + + + + + + + + + +

overrun

+

Trigger overrun state (true or false)

+

N

+

Trigger timer number (1 to 8)

+
+

Details

+

This command indicates if an event was ignored because the event detector was already in the detected state when the event occurred.

+

This is an indication of the state of the event detector built into the timer itself. It does not indicate if an overrun occurred in any other part of the trigger model or in any other construct that is monitoring the delay completion event. It also is not an indication of a delay overrun.

+

Delay overrun indications are provided in the status model.

+

Example

+

+ + + + + + +

print(trigger.timer[1].overrun)

+

If an event was ignored, the output is true.

+

If the event was not ignored, the output is false.

+
+

Also see

+

trigger.timer[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15798.htm b/WebHelpDocs/2601B-PULSE/15798.htm new file mode 100644 index 0000000..114cb64 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15798.htm @@ -0,0 +1,98 @@ + + + + + trigger.timer[N].passthrough + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].passthrough

+

This attribute enables or disables the timer trigger pass-through mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup
Trigger timer N reset

+

Not saved

+

false (disabled)

+
+

Usage

+

passthrough = trigger.timer[N].passthrough

+

trigger.timer[N].passthrough = passthrough

+

+ + + + + + + + + + +

passthrough

+

The state of pass-through mode; set to one of the following values:

+
  • true: Enabled
  • false: Disabled

N

+

Trigger timer number (1 to 8)

+
+

Details

+

When pass-through mode is enabled, triggers are passed through immediately and initiate the delay. When disabled, a trigger only initiates a delay.

+

Example

+

+ + + + + + +

trigger.timer[1].passthrough = true

+

Enables pass-through mode on trigger timer 1.

+
+

Also see

+

trigger.timer[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15800.htm b/WebHelpDocs/2601B-PULSE/15800.htm new file mode 100644 index 0000000..8b9f589 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15800.htm @@ -0,0 +1,107 @@ + + + + + trigger.timer[N].wait() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].wait()

+

This function waits for a trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

triggered = trigger.timer[N].wait(timeout)

+

+ + + + + + + + + + + + + + +

triggered

+

Trigger detection indication

+

N

+

Trigger timer number (1 to 8)

+

timeout

+

Maximum amount of time in seconds to wait for the trigger

+
+

Details

+

If one or more trigger events were detected since the last time trigger.timer[N].wait() or trigger.timer[N].clear() was called, this function returns immediately.

+

After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.

+

Example

+

+ + + + + + +

triggered = trigger.timer[3].wait(10)

+

print(triggered)

+

Waits up to 10 s for a trigger on timer 3.

+

If false is returned, no trigger was detected during the 10 s timeout.

+

If true is returned, a trigger was detected.

+
+

Also see

+

trigger.timer[N].clear()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15801.htm b/WebHelpDocs/2601B-PULSE/15801.htm new file mode 100644 index 0000000..579c37d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15801.htm @@ -0,0 +1,103 @@ + + + + + trigger.wait() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.wait()

+

This function waits for a command interface trigger event.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

triggered = trigger.wait(timeout)

+

+ + + + + + + + + + +

triggered

+

true: A trigger was detected during the timeout period

+

false: No triggers were detected during the timeout period

+

timeout

+

Maximum amount of time in seconds to wait for the trigger

+
+

Details

+

This function waits up to timeout seconds for a trigger on the active command interface. A command interface trigger occurs when:

+
  • A GPIB GET command is detected (GPIB only)
  • A USBTMC TRIGGER message is received (USB only)
  • A VXI-11 device_trigger method is invoked (VXI-11 only)
  • A *TRG message is received

If one or more of these trigger events were previously detected, this function returns immediately.

+

After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.

+

Example

+

+ + + + + + +

triggered = trigger.wait(10)

+

print(triggered)

+

Waits up to 10 seconds for a trigger.

+

If false is returned, no trigger was detected during the 10-second timeout.

+

If true is returned, a trigger was detected.

+
+

Also see

+

trigger.clear()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15820.htm b/WebHelpDocs/2601B-PULSE/15820.htm new file mode 100644 index 0000000..f79993f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15820.htm @@ -0,0 +1,104 @@ + + + + + trigger.timer[N].count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].count

+

This attribute sets the number of events to generate each time the timer generates a trigger event.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup
Trigger timer N reset

+

Not saved

+

1

+
+

Usage

+

count = trigger.timer[N].count

+

trigger.timer[N].count = count

+

+ + + + + + + + + + +

count

+

Number of times to repeat the trigger (0 to 1,048,575)

+

N

+

Trigger timer number (1 to 8)

+
+

Details

+

If the count is set to a number greater than 1, the timer automatically starts the next trigger timer delay at the expiration of the previous delay.

+

Set the count to zero (0) to cause the timer to generate trigger events indefinitely.

+

If you use the trigger timer with a trigger model, make sure the count value is the same or more than any count values expected in the trigger model.

+

Example

+

+ + + + + + + + +

print(trigger.timer[1].count)

+

Read trigger count for timer number 1.

+
+

Also see

+

trigger.timer[N].clear()

+

trigger.timer[N].delay

+

trigger.timer[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15830.htm b/WebHelpDocs/2601B-PULSE/15830.htm new file mode 100644 index 0000000..5cdda4a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15830.htm @@ -0,0 +1,338 @@ + + + + + status.node_enable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.node_enable

+

This attribute stores the system node enable register.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+
+

Usage

+

nodeEnableRegister = status.node_enable

+

status.node_enable = nodeEnableRegister

+

+ + + + + + +

nodeEnableRegister

+

The status of the system node enable register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

This attribute is used to read or write to the system node enable register. Reading the system node enable register returns a value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

Assigning a value to this attribute enables one or more status events. When an enabled status event occurs, a summary bit is set in the appropriate system summary register. The register and bit that is set depends on the TSP-Link node number assigned to this instrument.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.MEASUREMENT_SUMMARY_BIT

+

status.MSB

+

Set summary bit indicates that an enabled measurement event has occurred.

+

Bit B0 decimal value: 1

+

B1

+

Not used

+

B2

+

status.ERROR_AVAILABLE

+

status.EAV

+

Set summary bit indicates that an error or status message is present in the error queue.

+

Bit B2 decimal value: 4

+

B3

+

status.QUESTIONABLE_SUMMARY_BIT

+

status.QSB

+

Set summary bit indicates that an enabled questionable event has occurred.

+

Bit B3 decimal value: 8

+

B4

+

status.MESSAGE_AVAILABLE

+

status.MAV

+

Set summary bit indicates that a response message is present in the output queue.

+

Bit B4 decimal value: 16

+

B5

+

status.EVENT_SUMMARY_BIT

+

status.ESB

+

Set summary bit indicates that an enabled standard event has occurred.

+

Bit B5 decimal value: 32

+

B6

+

status.MASTER_SUMMARY_STATUS

+

status.MSS

+

Set bit indicates that an enabled Master Summary Status (MSS) bit of the Status Byte Register is set.

+

Bit B6 decimal value: 64

+

B7

+

status.OPERATION_SUMMARY_BIT

+

status.OSB

+

Set summary bit indicates that an enabled operation event has occurred.

+

Bit B7 decimal value: 128

+
+

As an example, to set the B0 bit of the system node enable register, set status.node_enable = status.MSB.

+

In addition to the above values, nodeEnableRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set nodeEnableRegister to the sum of their decimal weights. For example, to set bits B0 and B7, set nodeEnableRegister to 129 (1 + 128).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

Example 1

+

+ + + + + + + + +

nodeEnableRegister = status.MSB + status.OSB

+

status.node_enable = nodeEnableRegister

+

Use constants to set the MSB and OSB bits of the system node enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 129 = binary 10000001

+

nodeEnableRegister = 129

+

status.node_enable = nodeEnableRegister

+

Sets the MSB and OSB bits of the system node enable register using a decimal value.

+
+

Also see

+

status.condition

+

status.system.*

+

Status byte and service request (SRQ)

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15831.htm b/WebHelpDocs/2601B-PULSE/15831.htm new file mode 100644 index 0000000..bed0c2a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15831.htm @@ -0,0 +1,323 @@ + + + + + status.node_event + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.node_event

+

This attribute stores the status node event register.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not saved

+

0

+
+

Usage

+

nodeEventRegister = status.node_event

+

+ + + + + + +

nodeEventRegister

+

The status of the node event register; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

This attribute is used to read the status node event register, which is returned as a numeric value (reading this register returns a value). The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

The returned value can indicate one or more status events occurred.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.MEASUREMENT_SUMMARY_BIT

+

status.MSB

+

Set summary bit indicates that an enabled measurement event has occurred.

+

Bit B0 decimal value: 1

+

B1

+

Not used

+

B2

+

status.ERROR_AVAILABLE

+

status.EAV

+

Set summary bit indicates that an error or status message is present in the error queue.

+

Bit B2 decimal value: 4

+

B3

+

status.QUESTIONABLE_SUMMARY_BIT

+

status.QSB

+

Set summary bit indicates that an enabled questionable event has occurred.

+

Bit B3 decimal value: 8

+

B4

+

status.MESSAGE_AVAILABLE

+

status.MAV

+

Set summary bit indicates that a response message is present in the output queue.

+

Bit B4 decimal value: 16

+

B5

+

status.EVENT_SUMMARY_BIT

+

status.ESB

+

Set summary bit indicates that an enabled standard event has occurred.

+

Bit B5 decimal value: 32

+

B6

+

status.MASTER_SUMMARY_STATUS

+

status.MSS

+

Set bit indicates that an enabled Master Summary Status (MSS) bit of the Status Byte register is set.

+

Bit B6 decimal value: 64

+

B7

+

status.OPERATION_SUMMARY_BIT

+

status.OSB

+

Set summary bit indicates that an enabled operation event has occurred.

+

Bit B7 decimal value: 128

+
+

In addition to the above constants, nodeEventRegister can be set to the decimal equivalent of the bits set. When more than one bit of the register is set, nodeEventRegister contains the sum of their decimal weights. For example, if 129 is returned, bits B0 and B7 are set (1 + 128).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

Example

+

+ + + + + + + + +

nodeEventRegister = status.node_event

+

print(nodeEventRegister)

+

Reads the status node event register.

+

Sample output:

+

1.29000e+02

+

Converting this output (129) to its binary equivalent yields 1000 0001. Therefore, this output indicates that the set bits of the status byte condition register are presently B0 (MSB) and B7 (OSB).

+
+

Also see

+

Status byte and service request (SRQ)

+

status.condition

+

status.system.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15833.htm b/WebHelpDocs/2601B-PULSE/15833.htm new file mode 100644 index 0000000..a2bd476 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15833.htm @@ -0,0 +1,553 @@ + + + + + status.operation.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.*

+

These attributes manage the operation status register set of the status model.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

31,769 (All bits set)

+
+

Usage

+

operationRegister = status.operation.condition

+

operationRegister = status.operation.enable

+

operationRegister = status.operation.event

+

operationRegister = status.operation.ntr

+

operationRegister = status.operation.ptr

+

status.operation.enable = operationRegister

+

status.operation.ntr = operationRegister

+

status.operation.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes read or write the operation status registers.

+

Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 2.04800e+04 (which is 20,480) is read as the value of the condition register, the binary equivalent is 0101 0000 0000 0000. This value indicates that bit B14 (PROGRAM_RUNNING) and bit B12 (USER) are set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

1

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.operation.CALIBRATING

+

status.operation.CAL

+

Set bit indicates that the summary bit of the status.operation.calibrating register has been set.

+

Bit B0 decimal value: 1

+

B1 to B2

+

Not used

+

B3

+

status.operation.SWEEPING

+

status.operation.SWE

+

Set bit indicates that the summary bit from the status.operation.sweeping register is set.

+

Bit B3 decimal value: 8

+

B4

+

status.operation.MEASURING

+

status.operation.MEAS

+

Set bit indicates that the summary bit of the status.operation.measuring register is set.

+

Bit B4 decimal value: 16

+

B5 to B9

+

Not used

+

B10

+

status.operation.TRIGGER_OVERRUN

+

status.operation.TRGOVR

+

Set bit indicates that the summary bit from the status.operation.trigger_overrun register is set.

+

Bit B10 decimal value: 1,024

+

B11

+

status.operation.REMOTE_SUMMARY

+

status.operation.REM

+

Set bit indicates that the summary bit of the status.operation.remote register is set.

+

Bit B11 decimal value: 2,048

+

B12

+

status.operation.USER

+

Set bit indicates that the summary bit from the status.operation.user register is set.

+

Bit B12 decimal value: 4,096

+

B13

+

status.operation.INSTRUMENT_SUMMARY

+

status.operation.INST

+

Set bit indicates that the summary bit from the status.operation.instrument register is set.

+

Bit B13 decimal value: 8,192

+

B14

+

status.operation.PROGRAM_RUNNING

+

status.operation.PROG

+

Set bit indicates that a command or program is running.

+

Bit B14 decimal value: 16,384

+

B15

+

Not used

+
+

As an example, to set bit B12 of the operation status enable register, set status.operation.enable = status.operation.USER.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B12 and B14, set operationRegister to 20,480 (which is the sum of 4,096 + 16,384).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

operationRegister = status.operation.USER + status.operation.PROG

+

status.operation.enable = operationRegister

+

Uses constants to set the USER and PROG bits of the operation status enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 20480 = binary 0101 0000 0000 0000

+

operationRegister = 20480

+

status.operation.enable = operationRegister

+

Uses a decimal value to set the USER and PROG bits of the operation status enable register.

+
+

Also see

+

Operation Status Registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15836.htm b/WebHelpDocs/2601B-PULSE/15836.htm new file mode 100644 index 0000000..daf269c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15836.htm @@ -0,0 +1,208 @@ + + + + + status.operation.instrument.digio.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.digio.*

+

This attribute contains the operation status digital I/O summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

1024 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.digio.condition

+

operationRegister = status.operation.instrument.digio.enable

+

operationRegister = status.operation.instrument.digio.event

+

operationRegister = status.operation.instrument.digio.ntr

+

operationRegister = status.operation.instrument.digio.ptr

+

status.operation.instrument.digio.enable = operationRegister

+

status.operation.instrument.digio.ntr = operationRegister

+

status.operation.instrument.digio.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status digital I/O summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024

+
+

Details

+

These attributes are used to read or write to the operation status digital I/O summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0 to B9

+

Not used

+

B10

+

status.operation.instrument.digio.TRIGGER_OVERRUN

+

status.operation.instrument.digio.TRGOVR

+

Set bit indicates an enabled bit in the Operation Status Digital I/O Overrun Register is set.

+

Bit B10 decimal value: 1,024

+

Binary value: 0100 0000 0010

+

B11 to B15

+

Not used

+
+

In addition to the above constant, operationRegister can be set to the decimal value of the bit to set.

+

Example 1

+

+ + + + + + + + +

status.operation.instrument.digio.enable = status.operation.instrument.digio.TRGOVR

+

Uses a constant to set the TRGOVR bit of the operation status digital I/O summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.operation.instrument.digio.enable = 1024

+

Uses the decimal value to set the TRGOVR bit of the operation status digital I/O summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.digio.trigger_overrun.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15837.htm b/WebHelpDocs/2601B-PULSE/15837.htm new file mode 100644 index 0000000..5021200 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15837.htm @@ -0,0 +1,596 @@ + + + + + status.operation.instrument.digio.trigger_overrun.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.digio.trigger_overrun.*

+

This attribute contains the operation status digital I/O overrun register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

32,766 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.digio.trigger_overrun.condition

+

operationRegister = status.operation.instrument.digio.trigger_overrun.enable

+

operationRegister = status.operation.instrument.digio.trigger_overrun.event

+

operationRegister = status.operation.instrument.digio.trigger_overrun.ntr

+

operationRegister = status.operation.instrument.digio.trigger_overrun.ptr

+

status.operation.instrument.digio.trigger_overrun.enable = operationRegister

+

status.operation.instrument.digio.trigger_overrun.ntr = operationRegister

+

status.operation.instrument.digio.trigger_overrun.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status digio I/O overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status digital I/O overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

A set bit indicates that the specified digital I/O line generated an action overrun when it was triggered to generate an output trigger.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

Not used

+

Not applicable

+

B1

+

status.operation.instrument.digio.trigger_overrun.LINE1

+

2

+

B2

+

status.operation.instrument.digio.trigger_overrun.LINE2

+

4

+

B3

+

status.operation.instrument.digio.trigger_overrun.LINE3

+

8

+

B4

+

status.operation.instrument.digio.trigger_overrun.LINE4

+

16

+

B5

+

status.operation.instrument.digio.trigger_overrun.LINE5

+

32

+

B6

+

status.operation.instrument.digio.trigger_overrun.LINE6

+

64

+

B7

+

status.operation.instrument.digio.trigger_overrun.LINE7

+

128

+

B8

+

status.operation.instrument.digio.trigger_overrun.LINE8

+

256

+

B9

+

status.operation.instrument.digio.trigger_overrun.LINE9

+

512

+

B10

+

status.operation.instrument.digio.trigger_overrun.LINE10

+

1,024

+

B11

+

status.operation.instrument.digio.trigger_overrun.LINE11

+

2,048

+

B12

+

status.operation.instrument.digio.trigger_overrun.LINE12

+

4,096

+

B13

+

status.operation.instrument.digio.trigger_overrun.LINE13

+

8,192

+

B14

+

status.operation.instrument.digio.trigger_overrun.LINE14

+

16,384

+

B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B1 of the operation status digital I/O overrun enable register, set status.operation.instrument.digio.trigger_overrun.enable = status.operation.instrument.digio.trigger_overrun.LINE1.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1,024).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

operationRegister = status.operation.instrument.digio.trigger_overrun.LINE1 +

+

status.operation.instrument.digio.trigger_overrun.LINE10

+

status.operation.instrument.digio.trigger_overrun.enable = operationRegister

+

Uses constants to set bit B1 and bit B10 of the operation status digital I/O overrun enable register.

+
+

Example 2

+

+ + + + + + + + +

operationRegister = 1026

+

status.operation.instrument.digio.trigger_overrun.enable = operationRegister

+

Uses the decimal value to set bit B1 and bit B10 of the operation status digital I/O overrun enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.digio.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15838.htm b/WebHelpDocs/2601B-PULSE/15838.htm new file mode 100644 index 0000000..1056d79 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15838.htm @@ -0,0 +1,504 @@ + + + + + status.operation.instrument.lan.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.lan.*

+

This attribute contains the operation status LAN summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

1027 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.lan.condition

+

operationRegister = status.operation.instrument.lan.enable

+

operationRegister = status.operation.instrument.lan.event

+

operationRegister = status.operation.instrument.lan.ntr

+

operationRegister = status.operation.instrument.lan.ptr

+

status.operation.instrument.lan.enable = operationRegister

+

status.operation.instrument.lan.ntr = operationRegister

+

status.operation.instrument.lan.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status LAN summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status LAN summary registers. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.operation.instrument.lan.CONNECTION

+

status.operation.instrument.lan.CON

+

Set bit indicates that the LAN cable is connected and a link has been detected.

+

Bit B0 decimal value: 1

+

B1

+

status.operation.instrument.lan.CONFIGURING

+

status.operation.instrument.lan.CONF

+

Set bit indicates the LAN is performing its configuration sequence.

+

Bit B1 decimal value: 2

+

B2 to B9

+

Not used

+

B10

+

status.operation.instrument.lan.TRIGGER_OVERRUN

+

status.operation.instrument.lan.TRGOVR

+

Set bit indicates one or more enabled bits for the operation status LAN trigger overrun register is set.

+

Bit B10 decimal value: 1,024

+

B11 to B15

+

Not used

+
+

As an example, to set bit B0 of the operation status LAN summary enable register, set status.operation.instrument.lan.enable = status.operation.instrument.lan.CON.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1024).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

operationRegister = status.operation.instrument.lan.CONF +

+

status.operation.instrument.lan.TRGOVR

+

status.operation.instrument.lan.enable = operationRegister

+

Use constants to set bit B1 and bit B10 of the operation status LAN summary enable register.

+
+

Example 2

+

+ + + + + + + + +

operationRegister = 1026

+

status.operation.instrument.lan.enable = operationRegister

+

Use the decimal value to set bit B1 and bit B10 of the operation status LAN summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.lan.trigger_overrun.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15839.htm b/WebHelpDocs/2601B-PULSE/15839.htm new file mode 100644 index 0000000..b227ffe --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15839.htm @@ -0,0 +1,548 @@ + + + + + status.operation.instrument.lan.trigger_overrun.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.lan.trigger_overrun.*

+

This attribute contains the operation status LAN trigger overrun register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

510 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.lan.trigger_overrun.condition

+

operationRegister = status.operation.instrument.lan.trigger_overrun.enable

+

operationRegister = status.operation.instrument.lan.trigger_overrun.event

+

operationRegister = status.operation.instrument.lan.trigger_overrun.ntr

+

operationRegister = status.operation.instrument.lan.trigger_overrun.ptr

+

status.operation.instrument.lan.trigger_overrun.enable = operationRegister

+

status.operation.instrument.lan.trigger_overrun.ntr = operationRegister

+

status.operation.instrument.lan.trigger_overrun.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status LAN trigger overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status LAN trigger overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 2.58000e+02 (which is 258) is read as the value of the condition register, the binary equivalent is 0000 0001 0000 0010. This value indicates that bit B1 and bit B8 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

A set bit indicates that the specified LAN trigger generated an action overrun when triggered to generate a trigger packet.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

Not used

+

Not applicable

+

B1

+

status.operation.instrument.lan.trigger_overrun.LAN1

+

2

+

B2

+

status.operation.instrument.lan.trigger_overrun.LAN2

+

4

+

B3

+

status.operation.instrument.lan.trigger_overrun.LAN3

+

8

+

B4

+

status.operation.instrument.lan.trigger_overrun.LAN4

+

16

+

B5

+

status.operation.instrument.lan.trigger_overrun.LAN5

+

32

+

B6

+

status.operation.instrument.lan.trigger_overrun.LAN6

+

64

+

B7

+

status.operation.instrument.lan.trigger_overrun.LAN7

+

128

+

B8

+

status.operation.instrument.lan.trigger_overrun.LAN8

+

256

+

B9 to B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B1 of the operation status LAN trigger overrun enable register, set status.operation.instrument.lan.trigger_overrun.enable = status.operation.instrument.lan.trigger_overrun.LAN1.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B8, set operationRegister to 258 (which is the sum of 2 + 256).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

operationRegister = status.operation.instrument.lan.trigger_overrun.LAN1 +

+

status.operation.instrument.lan.trigger_overrun.LAN8

+

status.operation.instrument.lan.trigger_overrun.enable = operationRegister

+

Use constants to set bit B1 and bit B8 of the operation status LAN trigger overrun enable register.

+
+

Example 2

+

+ + + + + + + + +

operationRegister = 258

+

status.operation.instrument.lan.trigger_overrun.enable = operationRegister

+

Use the decimal value to set bit B1 and bit B8 of the operation status LAN trigger overrun enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.lan.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15840.htm b/WebHelpDocs/2601B-PULSE/15840.htm new file mode 100644 index 0000000..306ed42 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15840.htm @@ -0,0 +1,515 @@ + + + + + status.operation.instrument.smua.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.smua.*

+

This attribute contains the operation status SMU summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

1049 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.smua.condition

+

operationRegister = status.operation.instrument.smua.enable

+

operationRegister = status.operation.instrument.smua.event

+

operationRegister = status.operation.instrument.smua.ntr

+

operationRegister = status.operation.instrument.smua.ptr

+

status.operation.instrument.smua.enable = operationRegister

+

status.operation.instrument.smua.ntr = operationRegister

+

status.operation.instrument.smua.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status SMU summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status SMU summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02500e+02 (which is 1,025) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B0 and bit B10 are set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.operation.instrument.smua.CALIBRATING

+

status.operation.instrument.smua.CAL

+

Set bit indicates that smua is unlocked for calibration.

+

Bit B0 decimal value: 1

+

B1 to B2

+

Not used

+

B3

+

status.operation.instrument.smua.SWEEPING

+

status.operation.instrument.smua.SWE

+

Set bit indicates that smua is sweeping.

+

Bit B3 decimal value: 8

+

B4

+

status.operation.instrument.smua.MEASURING

+

status.operation.instrument.smua.MEAS

+

Bit is set when making an overlapped measurement, but it will not set when taking a normal synchronous measurement.

+

Bit B4 decimal value: 16

+

B5 to B9

+

Not used

+

B10

+

status.operation.instrument.smua.TRIGGER_OVERRUN

+

status.operation.instrument.smua.TRGOVR

+

Set bit indicates an enabled bit has been set in the operation status smua trigger overrun event register.

+

Bit B10 decimal value: 1,024

+

B11 to B15

+

Not used

+
+

As an example, to set bit B0 of the operation status SMU A summary enable register, set status.operation.instrument.smua.enable = status.operation.instrument.smua.CAL.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B0 and B10, set operationRegister to 1,025 (which is the sum of 1 + 1,024).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

status.operation.instrument.smua.enable = status.operation.instrument.smua.MEAS

+

Use a constant to set bit B4t of the operation status SMU A summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.operation.instrument.smua.enable = 1025

+

Use the decimal value to set bits B0 and B10 of the operation status SMU A summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.smua.trigger_overrrun.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15841.htm b/WebHelpDocs/2601B-PULSE/15841.htm new file mode 100644 index 0000000..75780dd --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15841.htm @@ -0,0 +1,506 @@ + + + + + status.operation.instrument.smua.trigger_overrrun.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.smua.trigger_overrrun.*

+

This attribute contains the operation status SMU trigger overrun register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

30 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.smua.trigger_overrun.condition

+

operationRegister = status.operation.instrument.smua.trigger_overrun.enable

+

operationRegister = status.operation.instrument.smua.trigger_overrun.event

+

operationRegister = status.operation.instrument.smua.trigger_overrun.ntr

+

operationRegister = status.operation.instrument.smua.trigger_overrun.ptr

+

status.operation.instrument.smua.trigger_overrun.enable = operationRegister

+

status.operation.instrument.smua.trigger_overrun.ntr = operationRegister

+

status.operation.instrument.smua.trigger_overrun.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status SMU trigger overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status SMU trigger overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 18 is read as the value of the condition register, the binary equivalent is 0000 0000 0001 0010. This value indicates that bit B1 and bit B4 are set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.operation.instrument.smua.trigger_overrun.ARM

+

Set bit indicates that the arm event detector of the SMU was already in the detected state when a trigger was received.

+

Bit B1 decimal value: 2

+

B2

+

status.operation.instrument.smua.trigger_overrun.SRC

+

Set bit indicates that the source event detector of the SMU was already in the detected state when a trigger was received.

+

Bit B2 decimal value: 4

+

B3

+

status.operation.instrument.smua.trigger_overrun.MEAS

+

Set bit indicates that the measurement event detector of the SMU was already in the detected state when a trigger was received.

+

Bit B3 decimal value: 8

+

B4

+

status.operation.instrument.smua.trigger_overrun.ENDP

+

Set bit indicates that the end pulse event detector of the SMU was already in the detected state when a trigger was received.

+

Bit B4 decimal value: 16

+

B5 to B15

+

Not used

+
+

As an example, to set bit B1 of the operation status SMU A trigger overrun enable register, set status.operation.instrument.smua.trigger_overrun.enable = 
status.operation.instrument.smua.trigger_overrun.ARM.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set operationRegister to 18 (which is the sum of 2 + 16).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

status.operation.instrument.smua.trigger_overrun.enable =

+

status.operation.instrument.smua.trigger_overrun.ARM

+

Uses a constant to sets the ARM bit of the operation status SMU A trigger overrun enable register.

+
+

Example 2

+

+ + + + + + + + +

status.operation.instrument.smua.trigger_overrun.enable = 18

+

Uses the decimal value to set bits B1 and B4 of the operation status SMU A trigger overrun enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.smua.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15842.htm b/WebHelpDocs/2601B-PULSE/15842.htm new file mode 100644 index 0000000..f1ac414 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15842.htm @@ -0,0 +1,195 @@ + + + + + status.operation.instrument.trigger_blender.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.trigger_blender.*

+

This attribute contains the operation status trigger blender summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

1024 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.trigger_blender.condition

+

operationRegister = status.operation.instrument.trigger_blender.enable

+

operationRegister = status.operation.instrument.trigger_blender.event

+

operationRegister = status.operation.instrument.trigger_blender.ntr

+

operationRegister = status.operation.instrument.trigger_blender.ptr

+

status.operation.instrument.trigger_blender.enable = operationRegister

+

status.operation.instrument.trigger_blender.ntr = operationRegister

+

status.operation.instrument.trigger_blender.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status trigger blender summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024

+
+

Details

+

These attributes are used to read or write to the operation status trigger blender summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0 to B9

+

Not used

+

B10

+

status.operation.instrument.trigger_blender.TRIGGER_OVERRUN

+

status.operation.instrument.trigger_blender.TRGOVR

+

Set bit indicates one or more enabled bits for operation status trigger blender overrun register is set.

+

Bit B10 decimal value: 1,024

+

Binary value:
0100 0000 0000

+

B11 to B15

+

Not used

+
+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. For example, to set bit B10, set operationRegister to 1024.

+

Example

+

+ + + + + + + + +

status.operation.instrument.trigger_blender.enable = 1024

+

Uses a decimal value to set the TRGOVR bit of the operation status trigger blender summary enable.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.trigger_blender.trigger_overrun.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15844.htm b/WebHelpDocs/2601B-PULSE/15844.htm new file mode 100644 index 0000000..0e8ec24 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15844.htm @@ -0,0 +1,195 @@ + + + + + status.operation.instrument.trigger_timer.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.trigger_timer.*

+

This attribute contains the operation status trigger timer summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

1024 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.trigger_timer.condition

+

operationRegister = status.operation.instrument.trigger_timer.enable

+

operationRegister = status.operation.instrument.trigger_timer.event

+

operationRegister = status.operation.instrument.trigger_timer.ntr

+

operationRegister = status.operation.instrument.trigger_timer.ptr

+

status.operation.instrument.trigger_timer.enable = operationRegister

+

status.operation.instrument.trigger_timer.ntr = operationRegister

+

status.operation.instrument.trigger_timer.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status trigger timer summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024

+
+

Details

+

These attributes are used to read or write to the operation status trigger timer summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0 to B9

+

Not used

+

B10

+

status.operation.instrument.trigger_timer.TRIGGER_OVERRUN

+

status.operation.instrument.trigger_timer.TRGOVR

+

Set bit indicates one or more enabled bits for the operation status trigger timer overrun register is set.

+

Bit B10 decimal value: 1,024

+

Binary value:
0100 0000 0000

+

B11 to B15

+

Not used

+
+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. For example, to set bit B10, set operationRegister to 1024.

+

Example

+

+ + + + + + + + +

status.operation.instrument.trigger_timer.enable = 1024

+

Uses the decimal value to set the TRGOVR bit of the operation status trigger timer summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.trigger_timer.trigger_overrun.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15845.htm b/WebHelpDocs/2601B-PULSE/15845.htm new file mode 100644 index 0000000..9ec6eba --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15845.htm @@ -0,0 +1,553 @@ + + + + + status.operation.instrument.trigger_timer.trigger_overrun.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.trigger_timer.trigger_overrun.*

+

This attribute contains the operation status trigger timer overrun register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

510 (All bits set)

+
+

Usage

+

operationRegister =

+

status.operation.instrument.trigger_timer.trigger_overrun.condition

+

operationRegister =

+

status.operation.instrument.trigger_timer.trigger_overrun.enable

+

operationRegister =

+

status.operation.instrument.trigger_timer.trigger_overrun.event

+

operationRegister =

+

status.operation.instrument.trigger_timer.trigger_overrun.ntr

+

operationRegister =

+

status.operation.instrument.trigger_timer.trigger_overrun.ptr

+

status.operation.instrument.trigger_timer.trigger_overrun.enable =

+

operationRegister

+

status.operation.instrument.trigger_timer.trigger_overrun.ntr =

+

operationRegister

+

status.operation.instrument.trigger_timer.trigger_overrun.ptr =

+

operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status trigger timer trigger overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status trigger timer overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 18 is read as the value of the condition register, the binary equivalent is 0000 0000 0001 0010. This value indicates that bit B1 and bit B4 are set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

A set bit indicates the specified timer generated an action overrun because it was still processing a delay from a previous trigger when a new trigger was received.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

Not used

+

Not applicable

+

B1

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR1

+

2

+

B2

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR2

+

4

+

B3

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR3

+

8

+

B4

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR4

+

16

+

B5

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR5

+

32

+

B6

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR6

+

64

+

B7

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR7

+

128

+

B8

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR8

+

256

+

B9 to B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B1 of the operation status trigger timer trigger overrun enable register, set status.operation.instrument.trigger_timer.trigger_overrun.enable = status.operation.instrument.trigger_timer.trigger_overrun.TMR1.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set operationRegister to 18 (which is the sum of 2 + 16).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

status.operation.instrument.trigger_timer.trigger_overrun.enable =

+

status.operation.instrument.trigger_timer.trigger_overrun.TMR3

+

Uses a constant to set the timer 3 bit of the operation status trigger timer overrun enable register.

+
+

Example 2

+

+ + + + + + + + +

status.operation.instrument.trigger_timer.trigger_overrun.enable = 18

+

Uses a constant to set timer bits B1 and B4 of the operation status trigger timer overrun enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.trigger_timer.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15846.htm b/WebHelpDocs/2601B-PULSE/15846.htm new file mode 100644 index 0000000..082a00f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15846.htm @@ -0,0 +1,195 @@ + + + + + status.operation.instrument.tsplink.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.tsplink.*

+

This attribute contains the operation status TSP-Link summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

1024 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.tsplink.condition

+

operationRegister = status.operation.instrument.tsplink.enable

+

operationRegister = status.operation.instrument.tsplink.event

+

operationRegister = status.operation.instrument.tsplink.ntr

+

operationRegister = status.operation.instrument.tsplink.ptr

+

status.operation.instrument.tsplink.enable = operationRegister

+

status.operation.instrument.tsplink.ntr = operationRegister

+

status.operation.instrument.tsplink.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status TSP-Link summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024

+
+

Details

+

These attributes are used to read or write to the operation status TSP-Link summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0 to B9

+

Not used

+

B10

+

status.operation.instrument.tsplink.TRIGGER_OVERRUN

+

status.operation.instrument.tsplink.TRGOVR

+

Set bit indicates one or more enabled bits for the operation status TSP-Link overrun register is set.

+

Bit B10 decimal value: 1,024

+

Binary value:
0100 0000 0000

+

B11 to B15

+

Not used

+
+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. For example, to set bit B10, set operationRegister to 1024.

+

Example

+

+ + + + + + + + +

status.operation.instrument.tsplink.enable = 1024

+

Uses the decimal value to set the trigger overrun bit of the operation status TSP-Link summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.tsplink.trigger_overrun.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15847.htm b/WebHelpDocs/2601B-PULSE/15847.htm new file mode 100644 index 0000000..588f4dc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15847.htm @@ -0,0 +1,507 @@ + + + + + status.operation.instrument.tsplink.trigger_overrun.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.tsplink.trigger_overrun.*

+

This attribute contains the operation status TSP-Link overrun register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

14 (All bits set)

+
+

Usage

+

operationRegister =

+

status.operation.instrument.tsplink.trigger_overrun.condition

+

operationRegister = status.operation.instrument.tsplink.trigger_overrun.enable

+

operationRegister = status.operation.instrument.tsplink.trigger_overrun.event

+

operationRegister = status.operation.instrument.tsplink.trigger_overrun.ntr

+

operationRegister = status.operation.instrument.tsplink.trigger_overrun.ptr

+

status.operation.instrument.tsplink.trigger_overrun.enable = operationRegister

+

status.operation.instrument.tsplink.trigger_overrun.ntr = operationRegister

+

status.operation.instrument.tsplink.trigger_overrun.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status TSP-link overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status TSP-link overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 10 is read as the value of the condition register, the binary equivalent is 0000 0000 0000 1010. This value indicates that bit B1 and bit B3 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

A set bit indicates that the specified line generated an action overrun when triggered to generate an output trigger.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

Not used

+

Not applicable

+

B1

+

status.operation.instrument.tsplink.trigger_overrun.LINE1

+

2

+

B2

+

status.operation.instrument.tsplink.trigger_overrun.LINE2

+

4

+

B3

+

status.operation.instrument.tsplink.trigger_overrun.LINE3

+

8

+

B4 to B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B1 of the operation status TSP-Link overrun enable register, set status.operation.instrument.tsplink.trigger_overrun.enable = status.operation.instrument.tsplink.trigger_overrun.LINE1.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B3, set operationRegister to 10 (which is the sum of 2 + 8).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

status.operation.instrument.tsplink.trigger_overrun.enable =

+

status.operation.instrument.tsplink.trigger_overrun.LINE1

+

Uses a constant to set the line 1 bit of the operation status TSP-Link overrun enable register.

+
+

Example 2

+

+ + + + + + + + +

status.operation.instrument.tsplink.trigger_overrun.enable = 10

+

Uses the decimal value to set bits for lines 1 and 3 of the operation status TSP-Link overrun enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.trigger_timer.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15849.htm b/WebHelpDocs/2601B-PULSE/15849.htm new file mode 100644 index 0000000..40ac7a3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15849.htm @@ -0,0 +1,225 @@ + + + + + status.operation.remote.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.remote.*

+

This attribute contains the operation status remote summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2050 (All bits set)

+
+

Usage

+

operationRegister = status.operation.remote.condition

+

operationRegister = status.operation.remote.enable

+

operationRegister = status.operation.remote.event

+

operationRegister = status.operation.remote.ntr

+

operationRegister = status.operation.remote.ptr

+

status.operation.remote.enable = operationRegister

+

status.operation.remote.ntr = operationRegister

+

status.operation.remote.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status remote summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status remote summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.operation.remote.COMMAND_AVAILABLE

+

status.operation.remote.CAV

+

Set bit indicates there is a command available in the execution queue.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0000 0000 0010

+

B2 to B10

+

Not used

+

B11

+

status.operation.remote.PROMPTS_ENABLED

+

status.operation.remote.PRMPT

+

Set bit indicates command prompts are enabled.

+

Bit B11 decimal value: 2,048

+

Binary value: 0000 0100 0000 0000

+

B12 to B15

+

Not used

+
+

As an example, to set bit B1 of the operation status remote summary enable register, set status.operation.remote.enable = status.operation.remote.CAV.

+

In addition to the above constants, operationRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B1 and B11, set operationRegister to 2,050 (which is the sum of 2 + 2,048).

+

Example 1

+

+ + + + + + + + +

status.operation.remote.enable = status.operation.remote.CAV

+

Uses a constant to set the CAV bit, B1, of the operation status remote summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.operation.remote.enable = 2050

+

Uses the decimal value to set bits B1 and B11 of the operation status remote summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15852.htm b/WebHelpDocs/2601B-PULSE/15852.htm new file mode 100644 index 0000000..1b006f9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15852.htm @@ -0,0 +1,596 @@ + + + + + status.operation.user.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.user.*

+

These attributes manage the operation status user register set of the status model.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

32,767 (All bits set)

+
+

Usage

+

operationRegister = status.operation.user.condition

+

operationRegister = status.operation.user.enable

+

operationRegister = status.operation.user.event

+

operationRegister = status.operation.user.ntr

+

operationRegister = status.operation.user.ptr

+

status.operation.user.condition = operationRegister

+

status.operation.user.enable = operationRegister

+

status.operation.user.ntr = operationRegister

+

status.operation.user.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status user register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status user registers. Reading a status register returns a value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bits B0 and B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

status.operation.user.BIT0

+

1

+

B1

+

status.operation.user.BIT1

+

2

+

B2

+

status.operation.user.BIT2

+

4

+

B3

+

status.operation.user.BIT3

+

8

+

B4

+

status.operation.user.BIT4

+

16

+

B5

+

status.operation.user.BIT5

+

32

+

B6

+

status.operation.user.BIT6

+

64

+

B7

+

status.operation.user.BIT7

+

128

+

B8

+

status.operation.user.BIT8

+

256

+

B9

+

status.operation.user.BIT9

+

512

+

B10

+

status.operation.user.BIT10

+

1,024

+

B11

+

status.operation.user.BIT11

+

2,048

+

B12

+

status.operation.user.BIT12

+

4,096

+

B13

+

status.operation.user.BIT13

+

8,192

+

B14

+

status.operation.user.BIT14

+

16,384

+

B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B0 of the operation status user enable register, set status.operation.user.enable = status.operation.user.BIT0.

+

In addition to the above constants, operationRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B11 and B14, set operationRegister to 18,432 (which is the sum of 2,048 + 16,384).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

operationRegister = status.operation.user.BIT11 + status.operation.user.BIT14

+

status.operation.user.enable = operationRegister

+

Uses constants to set bits B11 and B14 of the operation status user enable register.

+
+

Example 2

+

+ + + + + + + + +

-- 18432 = binary 0100 1000 0000 0000

+

operationRegister = 18432

+

status.operation.enable = operationRegister

+

Uses the decimal value to set bits B11 and B14 of the operation status user enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15861.htm b/WebHelpDocs/2601B-PULSE/15861.htm new file mode 100644 index 0000000..4196c07 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15861.htm @@ -0,0 +1,81 @@ + + + + + status.reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.reset()

+

This function resets all bits in the status model.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

status.reset()

+

Details

+

This function clears all status data structure registers (enable, event, NTR, and PTR) to their default values. For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers.

+

Example

+

+ + + + + + +

status.reset()

+

Resets the instrument status model.

+
+

Also see

+

Status model

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15862.htm b/WebHelpDocs/2601B-PULSE/15862.htm new file mode 100644 index 0000000..241aa0f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15862.htm @@ -0,0 +1,458 @@ + + + + + status.standard.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.standard.*

+

These attributes manage the standard event status register set of the status model.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

253 (All bits set)

+
+

Usage

+

standardRegister = status.standard.condition

+

standardRegister = status.standard.enable

+

standardRegister = status.standard.event

+

standardRegister = status.standard.ntr

+

standardRegister = status.standard.ptr

+

status.standard.enable = standardRegister

+

status.standard.ntr = standardRegister

+

status.standard.ptr = standardRegister

+

+ + + + + + +

standardRegister

+

The status of the standard event status register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the standard event status registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

B0

+

status.standard.OPERATION_COMPLETE

+

status.standard.OPC

+

Set bit indicates that all pending selected instrument operations are completed and the instrument is ready to accept new commands. The bit is set in response to an *OPC command. The opc() function can be used in place of the *OPC command.

+

Bit B0 decimal value: 1

+

B1

+

Not used

+

B2

+

status.standard.QUERY_ERROR

+

status.standard.QYE

+

Set bit indicates that you attempted to read data from an empty Output Queue.

+

Bit B2 decimal value: 4

+

B3

+

status.standard.DEVICE_DEPENDENT_ERROR

+

status.standard.DDE

+

Set bit indicates that an instrument operation did not execute properly due to some internal condition.

+

Bit B3 decimal value: 8

+

B4

+

status.standard.EXECUTION_ERROR

+

status.standard.EXE

+

Set bit indicates that the instrument detected an error while trying to execute a command.

+

Bit B4 decimal value: 16

+

B5

+

status.standard.COMMAND_ERROR

+

status.standard.CME

+

Set bit indicates that a command error has occurred. Command errors include:

+

IEEE Std 488.2 syntax error: Instrument received a message that does not follow the defined syntax of the IEEE Std 488.2 standard.

+

Semantic error: Instrument received a command that was misspelled or received an optional IEEE Std 488.2 command that is not implemented.

+

GET error: The instrument received a Group Execute Trigger (GET) inside a program message.

+

Bit B5 decimal value: 32

+

B6

+

status.standard.USER_REQUEST

+

status.standard.URQ

+

Set bit indicates that the LOCAL key on the instrument front panel was pressed.

+

Bit B6 decimal value: 64

+

B7

+

status.standard.POWER_ON

+

status.standard.PON

+

Set bit indicates that the instrument has been turned off and turned back on since the last time this register has been read.

+

Bit B7 decimal value: 128

+

B8 to B15

+

Not used

+
+

As an example, to set bit B0 of the standard event status enable register, set status.standard.enable = status.standard.OPC.

+

In addition to the above constants, standardRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set standardRegister to the sum of their decimal weights. For example, to set bits B0 and B4, set standardRegister to 17 (which is the sum of 1 + 16).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

Example 1

+

+ + + + + + + + +

standardRegister = status.standard.OPC + status.standard.EXE

+

status.standard.enable = standardRegister

+

Uses constants to set the OPC and EXE bits of the standard event status enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 17 = binary 0001 0001

+

standardRegister = 17

+

status.standard.enable = standardRegister

+

Uses the decimal value to set the OPC and EXE bits of the standard event status enable register.

+
+

Also see

+

Standard Event Register

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15863.htm b/WebHelpDocs/2601B-PULSE/15863.htm new file mode 100644 index 0000000..07dc7bd --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15863.htm @@ -0,0 +1,595 @@ + + + + + status.system.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.system.*

+

These attributes manage the TSP-Link® system summary register of the status model for nodes 1 through 14.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

32,767 (All bits set)

+
+

Usage

+

enableRegister = status.system.condition

+

enableRegister = status.system.enable

+

enableRegister = status.system.event

+

enableRegister = status.system.ntr

+

enableRegister = status.system.ptr

+

status.system.enable = enableRegister

+

status.system.ntr = enableRegister

+

status.system.ptr = enableRegister

+

+ + + + + + +

enableRegister

+

The status of the system summary register; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

status.system.EXTENSION_BIT

+

status.system.EXT

+

1

+

B1

+

status.system.NODE1

+

2

+

B2

+

status.system.NODE2

+

4

+

B3

+

status.system.NODE3

+

8

+

B4

+

status.system.NODE4

+

16

+

B5

+

status.system.NODE5

+

32

+

B6

+

status.system.NODE6

+

64

+

B7

+

status.system.NODE7

+

128

+

B8

+

status.system.NODE8

+

256

+

B9

+

status.system.NODE9

+

512

+

B10

+

status.system.NODE10

+

1,024

+

B11

+

status.system.NODE11

+

2,048

+

B12

+

status.system.NODE12

+

4,096

+

B13

+

status.system.NODE13

+

8,192

+

B14

+

status.system.NODE14

+

16,384

+

B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B0 of the system summary status enable register, set status.system.enable = status.system.enable.EXT.

+

In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

enableRegister = status.system.NODE11 + status.system.NODE14

+

status.system.enable = enableRegister

+

Uses constants to set bits B11 and B14 of the system summary enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 18432 = binary 0100 1000 0000 0000

+

enableRegister = 18432

+

status.system.enable = enableRegister

+

Uses the decimal value to set bits B11 and B14 of the system summary enable register.

+
+

Also see

+

status.system2.*

+

System summary and standard event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15864.htm b/WebHelpDocs/2601B-PULSE/15864.htm new file mode 100644 index 0000000..99d77d9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15864.htm @@ -0,0 +1,597 @@ + + + + + status.system2.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.system2.*

+

These attributes manage the TSP-Link® system summary register of the status model for nodes 15 through 28.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

32,767 (All bits set)

+
+

Usage

+

enableRegister = status.system2.condition

+

enableRegister = status.system2.enable

+

enableRegister = status.system2.event

+

enableRegister = status.system2.ntr

+

enableRegister = status.system2.ptr

+

status.system2.enable = enableRegister

+

status.system2.ntr = enableRegister

+

status.system2.ptr = enableRegister

+

+ + + + + + +

enableRegister

+

The status of the system summary 2 register; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

status.system2.EXTENSION_BIT

+

status.system2.EXT

+

1

+

B1

+

status.system2.NODE15

+

2

+

B2

+

status.system2.NODE16

+

4

+

B3

+

status.system2.NODE17

+

8

+

B4

+

status.system2.NODE18

+

16

+

B5

+

status.system2.NODE19

+

32

+

B6

+

status.system2.NODE20

+

64

+

B7

+

status.system2.NODE21

+

128

+

B8

+

status.system2.NODE22

+

256

+

B9

+

status.system2.NODE23

+

512

+

B10

+

status.system2.NODE24

+

1,024

+

B11

+

status.system2.NODE25

+

2,048

+

B12

+

status.system2.NODE26

+

4,096

+

B13

+

status.system2.NODE27

+

8,192

+

B14

+

status.system2.NODE28

+

16,384

+

B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B0 of the system summary 2 enable register, set status.system2.enable = status.system2.EXT.

+

In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

enableRegister = status.system2.NODE25 + status.system2.NODE28

+

status.system2.enable = enableRegister

+

Uses constants to set bits B11 and B14 of the system summary 2 enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 18432 = binary 0100 1000 0000 0000

+

enableRegister = 18432

+

status.system2.enable = enableRegister

+

Uses the decimal value to set bits B11 and B14 of the system summary 2 enable register.

+
+

Also see

+

status.system.*

+

status.system3.*

+

System summary and standard event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15865.htm b/WebHelpDocs/2601B-PULSE/15865.htm new file mode 100644 index 0000000..acccd8f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15865.htm @@ -0,0 +1,597 @@ + + + + + status.system3.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.system3.*

+

These attributes manage the TSP-Link® system summary register of the status model for nodes 29 through 42.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

32,767 (All bits set)

+
+

Usage

+

enableRegister = status.system3.condition

+

enableRegister = status.system3.enable

+

enableRegister = status.system3.event

+

enableRegister = status.system3.ntr

+

enableRegister = status.system3.ptr

+

status.system3.enable = enableRegister

+

status.system3.ntr = enableRegister

+

status.system3.ptr = enableRegister

+

+ + + + + + +

enableRegister

+

The status of the system summary 3 register; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0 and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

status.system3.EXTENSION_BIT

+

status.system3.EXT

+

1

+

B1

+

status.system3.NODE29

+

2

+

B2

+

status.system3.NODE30

+

4

+

B3

+

status.system3.NODE31

+

8

+

B4

+

status.system3.NODE32

+

16

+

B5

+

status.system3.NODE33

+

32

+

B6

+

status.system3.NODE34

+

64

+

B7

+

status.system3.NODE35

+

128

+

B8

+

status.system3.NODE36

+

256

+

B9

+

status.system3.NODE37

+

512

+

B10

+

status.system3.NODE38

+

1,024

+

B11

+

status.system3.NODE39

+

2,048

+

B12

+

status.system3.NODE40

+

4,096

+

B13

+

status.system3.NODE41

+

8,192

+

B14

+

status.system3.NODE42

+

16,384

+

B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B0 of the system summary 3 enable register, set status.system3.enable = status.system3.EXT.

+

In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

enableRegister = status.system3.NODE39 + status.system3.NODE42

+

status.system3.enable = enableRegister

+

Uses constants to set bits B11 and B14 of the system summary 3 enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 18432 = binary 0100 1000 0000 0000

+

enableRegister = 18432

+

status.system3.enable = enableRegister

+

Uses the decimal value to set bits B11 and B14 of the system summary 3 enable register.

+
+

Also see

+

status.system2.*

+

status.system4.*

+

System summary and standard event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15866.htm b/WebHelpDocs/2601B-PULSE/15866.htm new file mode 100644 index 0000000..53fbfef --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15866.htm @@ -0,0 +1,597 @@ + + + + + status.system4.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.system4.*

+

These attributes manage the TSP-Link® system summary register of the status model for nodes 43 through 56.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

32,767 (All bits set)

+
+

Usage

+

enableRegister = status.system4.condition

+

enableRegister = status.system4.enable

+

enableRegister = status.system4.event

+

enableRegister = status.system4.ntr

+

enableRegister = status.system4.ptr

+

status.system4.enable = enableRegister

+

status.system4.ntr = enableRegister

+

status.system4.ptr = enableRegister

+

+ + + + + + +

enableRegister

+

The status of the system summary 4 register; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

status.system4.EXTENSION_BIT

+

status.system4.EXT

+

1

+

B1

+

status.system4.NODE43

+

2

+

B2

+

status.system4.NODE44

+

4

+

B3

+

status.system4.NODE45

+

8

+

B4

+

status.system4.NODE46

+

16

+

B5

+

status.system4.NODE47

+

32

+

B6

+

status.system4.NODE48

+

64

+

B7

+

status.system4.NODE49

+

128

+

B8

+

status.system4.NODE50

+

256

+

B9

+

status.system4.NODE51

+

512

+

B10

+

status.system4.NODE52

+

1,024

+

B11

+

status.system4.NODE53

+

2,048

+

B12

+

status.system4.NODE54

+

4,096

+

B13

+

status.system4.NODE55

+

8,192

+

B14

+

status.system4.NODE56

+

16,384

+

B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B0 of the system summary 4 enable register, set status.system4.enable = status.system4.enable.EXT.

+

In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

enableRegister = status.system4.NODE53 + status.system4.NODE56

+

status.system2.enable = enableRegister

+

Uses constants to set bit B11 and bit B14 of the system summary 4 enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 18432 = binary 0100 1000 0000 0000

+

enableRegister = 18432

+

status.system4.enable = enableRegister

+

Uses a decimal value to set bit B11 and bit B14 of the system summary 4 enable register.

+
+

Also see

+

status.system3.*

+

status.system5.*

+

System summary and standard event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15867.htm b/WebHelpDocs/2601B-PULSE/15867.htm new file mode 100644 index 0000000..1fda5a8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15867.htm @@ -0,0 +1,547 @@ + + + + + status.system5.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.system5.*

+

These attributes manage the TSP-Link® system summary register of the status model for nodes 57 through 64.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

510 (All bits set)

+
+

Usage

+

enableRegister = status.system5.condition

+

enableRegister = status.system5.enable

+

enableRegister = status.system5.event

+

enableRegister = status.system5.ntr

+

enableRegister = status.system5.ptr

+

status.system5.enable = enableRegister

+

status.system5.ntr = enableRegister

+

status.system5.ptr = enableRegister

+

+ + + + + + +

enableRegister

+

The status of the system summary 5 register; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value, but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.30000e+02 (which is 130) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0010. This value indicates that bit B1 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

Not used

+

Not applicable

+

B1

+

status.system5.NODE57

+

2

+

B2

+

status.system5.NODE58

+

4

+

B3

+

status.system5.NODE59

+

8

+

B4

+

status.system5.NODE60

+

16

+

B5

+

status.system5.NODE61

+

32

+

B6

+

status.system5.NODE62

+

64

+

B7

+

status.system5.NODE63

+

128

+

B8

+

status.system5.NODE64

+

256

+

B9 to B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B1 of the system summary 5 enable register, set status.system5.enable = status.system5.NODE57.

+

In addition to the above constants, enableRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set enableRegister to 18 (which is the sum of 2 + 16).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

enableRegister = status.system5.NODE57 + status.system5.NODE60

+

status.system2.enable = enableRegister

+

Uses constants to set bits B1 and B4 of the system summary 5 enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 18 = binary 0000 0000 0001 0010

+

enableRegister = 18

+

status.system5.enable = enableRegister

+

Uses the decimal value to set bits B1 and B4 of the system summary 5 enable register.

+
+

Also see

+

status.system4.*

+

System summary and standard event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/15965.htm b/WebHelpDocs/2601B-PULSE/15965.htm new file mode 100644 index 0000000..ce6e9fa --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/15965.htm @@ -0,0 +1,68 @@ + + + + + Display + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Display

+

display.clear()

+

display.getannunciators()

+

display.getcursor()

+

display.getlastkey()

+

display.gettext()

+

display.inputvalue()

+

display.loadmenu.add()

+

display.loadmenu.catalog()

+

display.loadmenu.delete()

+

display.locallockout

+

display.menu()

+

display.numpad

+

display.prompt()

+

display.screen

+

display.sendkey()

+

display.setcursor()

+

display.settext()

+

display.smua.digits

+

display.smua.limit.func

+

display.smua.measure.func

+

display.trigger.clear()

+

display.trigger.EVENT_ID

+

display.trigger.overrun

+

display.trigger.wait()

+

display.waitkey()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16803.htm b/WebHelpDocs/2601B-PULSE/16803.htm new file mode 100644 index 0000000..2fc0baf --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16803.htm @@ -0,0 +1,46 @@ + + + + + Save a user script + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Save a user script

+

You can save scripts to nonvolatile memory using commands.

+

Only named scripts can be saved to nonvolatile memory. The anonymous script must be named before it can be saved to nonvolatile memory.

+

VARIABLE - NOTE
If a script is not saved to nonvolatile memory, the script is lost when the instrument is turned off.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16805.htm b/WebHelpDocs/2601B-PULSE/16805.htm new file mode 100644 index 0000000..1bf22cb --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16805.htm @@ -0,0 +1,59 @@ + + + + + Delete user scripts + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Delete user scripts

+

VARIABLE - NOTE
These steps remove a script from nonvolatile memory. To completely remove a script from the instrument, there are additional steps you must take. See Delete user scripts from the instrument.

+

To delete a script from nonvolatile memory using a remote interface:

+

You can delete the script from nonvolatile memory by sending either of the following commands:

+
  • script.delete("name")
  • script.user.delete("name")

Where: name is the user-defined name of the script.

+

Example: Delete a user script from nonvolatile memory

+

+ + + + + + +

script.delete("test8")

+

Delete a user script named test8 from nonvolatile memory.

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16851.htm b/WebHelpDocs/2601B-PULSE/16851.htm new file mode 100644 index 0000000..caf776e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16851.htm @@ -0,0 +1,91 @@ + + + + + script.restore() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.restore()

+

This function restores a script that was removed from the runtime environment.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

script.restore(name)

+

+ + + + + + +

name

+

The name of the script to be restored

+
+

Details

+

This command copies the script from nonvolatile memory into the runtime environment. It also creates a global variable with the same name as the name of the script.

+

Example

+

+ + + + + + +

script.restore("test9")

+

Restores a script named test9 from nonvolatile memory.

+
+

Also see

+

script.delete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16852.htm b/WebHelpDocs/2601B-PULSE/16852.htm new file mode 100644 index 0000000..413a9ab --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16852.htm @@ -0,0 +1,103 @@ + + + + + scriptVar.autorun + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

scriptVar.autorun

+

This attribute controls the autorun state of a script.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

No

+

Not applicable

+

See Details

+

See Details

+
+

Usage

+

scriptVar.autorun = "state"

+

state = scriptVar.autorun

+

+ + + + + + + + + + +

scriptVar

+

The name of the variable that references the script

+

state

+

String that indicates whether or not the script runs automatically when powered on:

+
  • yes: Script runs automatically
  • no: Script does not run automatically
+

Details

+

Autorun scripts run automatically when the instrument is turned on. You can set any number of scripts to autorun.

+

The run order for autorun scripts is arbitrary, so make sure the run order is not important.

+

The default value for scriptVar.autorun depends on how the script was loaded. The default is no if the script was loaded with loadscript or script.new(). It is yes for scripts loaded with loadandrunscript or script.newautorun().

+

VARIABLE - NOTE
Make sure to save the script in nonvolatile memory after setting the autorun attribute so that the instrument keeps the setting.

+

Example

+

+ + + + + + +

test5.autorun = "yes"

+

test5.save()

+

Assume a script named test5 is in the runtime environment.

+

The next time the instrument is turned on, test5 script automatically loads and runs.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16853.htm b/WebHelpDocs/2601B-PULSE/16853.htm new file mode 100644 index 0000000..a2096b7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16853.htm @@ -0,0 +1,90 @@ + + + + + script.delete() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.delete()

+

This function deletes a script from nonvolatile memory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

script.delete("scriptName")

+

+ + + + + + +

scriptName

+

The string that represents the name of the script

+
+

Example

+

+ + + + + + +

script.delete("test8")

+

Deletes a user script named "test8" from nonvolatile memory.

+
+

Also see

+

Delete user scripts from the instrument

+

scriptVar.save()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16856.htm b/WebHelpDocs/2601B-PULSE/16856.htm new file mode 100644 index 0000000..ef7a3fa --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16856.htm @@ -0,0 +1,93 @@ + + + + + scriptVar.run() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

scriptVar.run()

+

This function runs a script.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

scriptVar.run()

+

scriptVar()

+

+ + + + + + +

scriptVar

+

The name of the variable that references the script

+
+

Details

+

The scriptVar.run() function runs the script referenced by scriptVar. You can also run the script by using scriptVar().

+

To run a factory script, use script.factory.scripts.scriptName(), replacing scriptName with the name of the factory script.

+

Example

+

+ + + + + + +

test8.run()

+

Runs the script referenced by the variable test8.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16862.htm b/WebHelpDocs/2601B-PULSE/16862.htm new file mode 100644 index 0000000..68a1710 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16862.htm @@ -0,0 +1,100 @@ + + + + + script.user.catalog() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.user.catalog()

+

This function returns an iterator that can be used in a for loop to iterate over all the scripts stored in nonvolatile memory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

for name in script.user.catalog() do body end

+

+ + + + + + + + + + +

name

+

String representing the name of the script

+

body

+

Code that implements the body of the for loop to process the names in the catalog

+
+

Details

+

This function accesses the catalog of scripts stored in nonvolatile memory, which allows you to process all scripts in nonvolatile memory. The entries are enumerated in no particular order.

+

Each time the body of the function executes, name takes on the name of one of the scripts stored in nonvolatile memory. The for loop repeats until all scripts have been iterated.

+

Example

+

+ + + + + + +

for name in script.user.catalog() do

+

print(name)

+

end

+

Retrieve the catalog listing for user scripts.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16863.htm b/WebHelpDocs/2601B-PULSE/16863.htm new file mode 100644 index 0000000..f7d2b84 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16863.htm @@ -0,0 +1,111 @@ + + + + + scriptVar.save() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

scriptVar.save()

+

This function saves the script to nonvolatile memory or to a USB flash drive.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

scriptVar.save()

+

scriptVar.save("filename")

+

+ + + + + + + + + + +

scriptVar

+

The name of variable that references the script

+

filename

+

A string that contains the file name to use when saving the script to a USB flash drive

+
+

Details

+

The scriptVar.save() function saves a script to nonvolatile memory or a USB flash drive. The root folder of the USB flash drive has the absolute path /usb1/.

+

If no filename is specified (the file name parameter is an empty string), the script is saved to internal nonvolatile memory. Only a script with filename defined can be saved to internal nonvolatile memory. If a filename is given, the script is saved to the USB flash drive.

+

You can add the file extension, but it is not required. The only allowed extension is .tsp (see Example 2).

+

Example 1

+

+ + + + + + +

test8.save()

+

Saves the script referenced by the variable test8 to nonvolatile memory.

+
+

Example 2

+

+ + + + + + +

test8.save("/usb1/myScript.tsp")

+

Saves the script referenced by the variable test8 to a file named myScript.tsp on your USB flash drive.

+
+

Also see

+

Save a user script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16867.htm b/WebHelpDocs/2601B-PULSE/16867.htm new file mode 100644 index 0000000..0e0b0e7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16867.htm @@ -0,0 +1,105 @@ + + + + + scriptVar.source + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

scriptVar.source

+

This attribute contains the source code of a script.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)
(see Details)

+

No

+

Not applicable

+

Not saved

+

Not applicable

+
+

Usage

+

code = scriptVar.source

+

scriptVar.source = nil

+

+ + + + + + + + + + +

scriptVar

+

The name of the variable that references the script that contains the source code

+

code

+

A string that contains the body of the script

+
+

Details

+

The loadscript or loadandrunscript and endscript keywords are not included in the source code.

+

The body of the script is a single string with lines separated by the new line character.

+

The instrument automatically stores the source for all scripts that are loaded on the instrument. To free up memory or to obfuscate the code, assign nil to the source attribute of the script. Although this attribute is writable, it can only be set to the nil value.

+

Example

+

+ + + + + + + + +

test7 = script.new("display.clear() display.settext('Hello from my test')", "")

+

print(test7.source)

+

This example creates a script called test7 that displays a message on the front panel and retrieves the source code.

+

Output:

+

display.clear() display.settext('Hello from my test')

+
+

Also see

+

scriptVar.list()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/16978.htm b/WebHelpDocs/2601B-PULSE/16978.htm new file mode 100644 index 0000000..c646e77 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/16978.htm @@ -0,0 +1,85 @@ + + + + + localnode.reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.reset()

+

This function resets the local node instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

localnode.reset()

+

Details

+

If you want to reset a specific instrument or a subordinate node, use the node[X].reset() command.

+

A local node reset includes:

+
  • Source-measure unit (SMU) attributes affected by a SMU reset are reset
  • Other settings are restored back to factory default settings

A localnode.reset() is different than a reset() because reset() resets the entire system.

+

When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].reset().

+

Example

+

+ + + + + + +

localnode.reset()

+

Resets the local node.

+
+

Also see

+

reset()

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17029.htm b/WebHelpDocs/2601B-PULSE/17029.htm new file mode 100644 index 0000000..763f298 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17029.htm @@ -0,0 +1,47 @@ + + + + + Introduction to TSP operation + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Introduction to TSP operation

+

Instruments that are enabled for Test Script Processor (TSP®) operate like conventional instruments by responding to a sequence of commands sent by the controller. You can send individual commands to the TSP-enabled instrument the same way you would when using any other instrument.

+

Unlike conventional instruments, TSP-enabled instruments can execute automated test sequences independently, without an external controller. You can load a series of TSP commands into the instrument. You can store these commands as a script that can be run later by sending a single command message to the instrument.

+

You do not have to choose between using conventional control or script control. You can combine these forms of instrument control in the way that works best for your test application.

+ + + + + +
+

In this section

Controlling the instrument by sending individual command messages

Queries

Information on scripting and programming

+

See also

Remote commands

About TSP commands

Factory scripts

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17030.htm b/WebHelpDocs/2601B-PULSE/17030.htm new file mode 100644 index 0000000..9194206 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17030.htm @@ -0,0 +1,67 @@ + + + + + Retrieve source code one line at a time + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Retrieve source code one line at a time

+

To retrieve the source code one line at a time, send the scriptVar.list() command. When this command is received, the instrument sends the entire script. Each line of the script is sent as a separate response message. The output includes the loadscript or loadandrunscript and endscript keywords.

+

After retrieving the source code, you can modify and save the command lines as a user script under the same name or a new name.

+

To retrieve the source code of a script one line at a time, send the command:

+

scriptVar.list()

+

Where scriptVar is the name of the script.

+

VARIABLE - NOTE
To retrieve the commands in the anonymous script, use script.anonymous.list().

+

Example: Retrieve source code one line at a time

+

+ + + + + + +

test.list()

+

Retrieve the source of a script named "test".

+

The output will look similar to:

+

loadscript test

+

display.clear()

+

display.settext("This is a test")

+

print("This is a test")

+

endscript

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17040.htm b/WebHelpDocs/2601B-PULSE/17040.htm new file mode 100644 index 0000000..6028c4f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17040.htm @@ -0,0 +1,109 @@ + + + + + script.anonymous + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.anonymous

+

This is a reference to the anonymous script.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

No

+

See Details

+

See Details

+

Not applicable

+
+

Usage

+

scriptVar = script.anonymous

+

+ + + + + + +

scriptVar

+

The name of the variable that references the script

+
+

Details

+

You can use the script.anonymous script like any other script. Also, you can save the anonymous script as a user script by giving it a name.

+

This script is replaced by loading a script with the loadscript or loadandrunscript commands when they are used without a name.

+

Example 1

+

+ + + + + + +

script.anonymous.list()

+

Displays the content of the anonymous script.

+
+

Example 2

+

+ + + + + + +

print(script.anonymous.source)

+

Retrieves the source of the anonymous script.

+
+

Also see

+

Anonymous scripts

+

scriptVar.autorun

+

scriptVar.list()

+

scriptVar.name

+

scriptVar.run()

+

scriptVar.save()

+

scriptVar.source

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17109.htm b/WebHelpDocs/2601B-PULSE/17109.htm new file mode 100644 index 0000000..e362099 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17109.htm @@ -0,0 +1,101 @@ + + + + + bufferVar.cachemode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.cachemode

+

This attribute enables or disables the reading buffer cache (on or off).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Not saved

+

1 (enabled)

+
+

Usage

+

cacheMode = bufferVar.cachemode

+

bufferVar.cachemode = cacheMode

+

+ + + + + + + + + + +

cacheMode

+

The reading buffer cache mode; set to one of the following:

+
  • 0: Cache mode disabled (off)
  • 1: Cache mode enabled (on)

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+
+

Details

+

Assigning a value to this attribute enables or disables the reading buffer cache. When enabled, the reading buffer cache improves access speed to reading buffer data.

+

If you run successive operations that overwrite reading buffer data, the reading buffer may return stale cache data. This can happen when initiating successive sweeps without reconfiguring the sweep measurements or when overwriting data in the reading buffer by setting the bufferVar.fillmode attribute to smua.FILL_WINDOW. To avoid this, make sure that you include commands that automatically invalidate the cache as needed (for example, explicit calls to the bufferVar.clearcache() function) or disable the cache using this attribute (bufferVar.cachemode).

+

Example

+

+ + + + + + +

smua.nvbuffer1.cachemode = 1

+

Enables reading buffer cache of dedicated reading buffer 1 (source-measure unit (SMU) channel A).

+
+

Also see

+

bufferVar.clearcache()

+

bufferVar.fillmode

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17112.htm b/WebHelpDocs/2601B-PULSE/17112.htm new file mode 100644 index 0000000..2862cda --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17112.htm @@ -0,0 +1,71 @@ + + + + + Reading buffer + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Reading buffer

+

Reading buffers capture measurements, ranges, instrument status, and output states of the instrument.

+

bufferVar.appendmode

+

bufferVar.basetimestamp

+

bufferVar.cachemode

+

bufferVar.capacity

+

bufferVar.clear()

+

bufferVar.clearcache()

+

bufferVar.collectsourcevalues

+

bufferVar.collecttimestamps

+

bufferVar.fillcount

+

bufferVar.fillmode

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestampresolution

+

bufferVar.timestamps

+

savebuffer()

+

smua.buffer.getstats()

+

smua.buffer.recalculatestats()

+

smua.makebuffer()

+

smua.nvbufferY

+

smua.savebuffer()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17268.htm b/WebHelpDocs/2601B-PULSE/17268.htm new file mode 100644 index 0000000..3c810cc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17268.htm @@ -0,0 +1,47 @@ + + + + + Controlling the instrument by sending individual command messages + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Controlling the instrument by sending individual command messages

+

The simplest method of controlling an instrument through the communication interface is to send it a message that contains remote commands. You can use a test program that resides on a computer (the controller) to sequence the actions of the instrument.

+

TSP commands can be function-based or attribute-based. Function-based commands are commands that control actions or activities. Attribute-based commands define characteristics of an instrument feature or operation.

+

Constants represent fixed values.

+ + + + + +
+

In this section

Functions

Attributes

+

See also

Introduction to TSP operation

Queries

Information on scripting and programming

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17630.htm b/WebHelpDocs/2601B-PULSE/17630.htm new file mode 100644 index 0000000..03ccde8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17630.htm @@ -0,0 +1,96 @@ + + + + + tsplink.writeprotect + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.writeprotect

+

This attribute contains the write-protect mask that protects bits from changes by the tsplink.writebit() and tsplink.writeport() functions.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Saved setup

+

0

+
+

Usage

+

mask = tsplink.writeprotect

+

tsplink.writeprotect = mask

+

+ + + + + + +

mask

+

An integer that specifies the value of the bit pattern for write-protect; set bits to 1 to write-protect the corresponding TSP-Link trigger line

+
+

Details

+

The binary equivalent of mask indicates the mask to be set for the TSP-Link trigger line. For example, a mask value of 5 has a binary equivalent of 101. This mask write-protects TSP-Link trigger lines 1 and 3.

+

Example

+

+ + + + + + +

tsplink.writeprotect = 5

+

Write-protects TSP-Link trigger lines 1 and 3.

+
+

Also see

+

Controlling digital I/O lines

+

tsplink.readbit()

+

tsplink.readport()

+

tsplink.writebit()

+

tsplink.writeport()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17645.htm b/WebHelpDocs/2601B-PULSE/17645.htm new file mode 100644 index 0000000..9e53f26 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17645.htm @@ -0,0 +1,129 @@ + + + + + print() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

print()

+

This function generates a response message.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

print(value1)

+

print(value1, value2)

+

print(value1, ..., valueN)

+

+ + + + + + + + + + + + + + + + + + +

value1

+

The first argument to output

+

value2

+

The second argument to output

+

valueN

+

The last argument to output

+

...

+

One or more values separated with commas

+
+

Details

+

TSP-enabled instruments do not have inherent query commands. Like other scripting environments, the print() command and other related print() commands generate output. The print() command creates one response message.

+

The output from multiple arguments is separated with a tab character.

+

Numbers are printed using the format.asciiprecision attribute. If you want use Lua formatting, print the return value from the tostring() function.

+

Example 1

+

+ + + + + + +

x = 10

+

print(x)

+

Example of an output response message:

+

10

+

Note that your output might be different if you set your ASCII precision setting to a different value.

+
+

Example 2

+

+ + + + + + +

x = true

+

print(tostring(x))

+

Example of an output response message:

+

true

+
+

Also see

+

format.asciiprecision

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17666.htm b/WebHelpDocs/2601B-PULSE/17666.htm new file mode 100644 index 0000000..e7053c5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17666.htm @@ -0,0 +1,94 @@ + + + + + trigger.blender[N].reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.blender[N].reset()

+

This function resets some of the trigger blender settings to their factory defaults.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

trigger.blender[N].reset()

+

+ + + + + + +

N

+

The trigger event blender (up to six)

+
+

Details

+

The trigger.blender[N].reset() function resets the following attributes to their factory defaults:

+
  • trigger.blender[N].orenable
  • trigger.blender[N].stimulus[M]

It also clears trigger.blender[N].overrun.

+

Example

+

+ + + + + + +

trigger.blender[1].reset()

+

Resets the trigger blender 1 settings to factory defaults.

+
+

Also see

+

trigger.blender[N].orenable

+

trigger.blender[N].overrun

+

trigger.blender[N].stimulus[M]

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17668.htm b/WebHelpDocs/2601B-PULSE/17668.htm new file mode 100644 index 0000000..4c7eb65 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17668.htm @@ -0,0 +1,97 @@ + + + + + trigger.timer[N].reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].reset()

+

This function resets some of the trigger timer settings to their factory defaults.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

trigger.timer[N].reset()

+

+ + + + + + +

N

+

Trigger timer number (1 to 8)

+
+

Details

+

The trigger.timer[N].reset() function resets the following attributes to their factory defaults:

+
  • trigger.timer[N].count
  • trigger.timer[N].delay
  • trigger.timer[N].delaylist
  • trigger.timer[N].passthrough
  • trigger.timer[N].stimulus

It also clears trigger.timer[N].overrun.

+

Example

+

+ + + + + + +

trigger.timer[1].reset()

+

Resets the attributes associated with timer 1 back to factory default values.

+
+

Also see

+

trigger.timer[N].count

+

trigger.timer[N].delay

+

trigger.timer[N].delaylist

+

trigger.timer[N].overrun

+

trigger.timer[N].passthrough

+

trigger.timer[N].stimulus

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17669.htm b/WebHelpDocs/2601B-PULSE/17669.htm new file mode 100644 index 0000000..ae97980 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17669.htm @@ -0,0 +1,95 @@ + + + + + tsplink.trigger[N].reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].reset()

+

This function resets some of the TSP-Link trigger attributes to their factory defaults.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

tsplink.trigger[N].reset()

+

+ + + + + + +

N

+

The trigger line (1 to 3)

+
+

Details

+

The tsplink.trigger[N].reset() function resets the following attributes to their factory defaults:

+
  • tsplink.trigger[N].mode
  • tsplink.trigger[N].stimulus
  • tsplink.trigger[N].pulsewidth

This also clears tsplink.trigger[N].overrun.

+

Example

+

+ + + + + + +

tsplink.trigger[3].reset()

+

Resets TSP-Link trigger line 3 attributes back to factory default values.

+
+

Also see

+

tsplink.trigger[N].mode

+

tsplink.trigger[N].overrun

+

tsplink.trigger[N].pulsewidth

+

tsplink.trigger[N].stimulus

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17679.htm b/WebHelpDocs/2601B-PULSE/17679.htm new file mode 100644 index 0000000..859352e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17679.htm @@ -0,0 +1,216 @@ + + + + + lan.trigger[N].stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.trigger[N].stimulus

+

This attribute specifies events that cause this trigger to assert.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
LAN trigger N reset
Recall setup

+

Not saved

+

0

+
+

Usage

+

triggerStimulus = lan.trigger[N].stimulus

+

lan.trigger[N].stimulus = triggerStimulus

+

+ + + + + + + + + + +

triggerStimulus

+

The LAN event identifier used to trigger the event

+

N

+

A number specifying the trigger packet over the LAN for which to set or query the trigger source (1 to 8)

+
+

Details

+

This attribute specifies which event causes a LAN trigger packet to be sent for this trigger. Set triggerStimulus to one of the trigger event IDs, which are shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Setting this attribute to zero disables automatic trigger generation.

+

If any events are detected prior to calling lan.trigger[N].connect(), the event is ignored and the action overrun is set.

+

Example

+

+ + + + + + + + +

lan.trigger[5].stimulus = trigger.timer[1].EVENT_ID

+

Use timer 1 trigger event as the source for LAN packet 5 trigger stimulus.

+
+

Also see

+

lan.trigger[N].assert()

+

lan.trigger[N].clear()

+

lan.trigger[N].connect()

+

lan.trigger[N].overrun

+

lan.trigger[N].wait()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17682.htm b/WebHelpDocs/2601B-PULSE/17682.htm new file mode 100644 index 0000000..7c21b1d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17682.htm @@ -0,0 +1,212 @@ + + + + + tsplink.trigger[N].stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

tsplink.trigger[N].stimulus

+

This attribute specifies the event that causes the synchronization line to assert a trigger.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup
TSP-Link trigger N reset

+

Not saved

+

0

+
+

Usage

+

eventID = tsplink.trigger[N].stimulus

+

tsplink.trigger[N].stimulus = eventID

+

+ + + + + + + + + + +

eventID

+

The event identifier for the triggering event

+

N

+

The trigger line (1 to 3)

+
+

Details

+

To disable automatic trigger assertion on the synchronization line, set this attribute to zero (0).

+

Do not use this attribute when triggering under script control. Use tsplink.trigger[N].assert() instead.

+

The eventID parameter may be one of the existing trigger event IDs shown in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Example

+

+ + + + + + +

print(tsplink.trigger[3].stimulus)

+

Prints the event that will start TSP-Link trigger line 3 action.

+
+

Also see

+

tsplink.trigger[N].assert()

+

tsplink.trigger[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17684.htm b/WebHelpDocs/2601B-PULSE/17684.htm new file mode 100644 index 0000000..b4a4289 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17684.htm @@ -0,0 +1,223 @@ + + + + + trigger.blender[N].stimulus[M] + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.blender[N].stimulus[M]

+

This attribute specifies the events that trigger the blender.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Trigger blender N reset

+

Not applicable

+

trigger.EVENT_NONE

+
+

Usage

+

eventID = trigger.blender[N].stimulus[M]

+

trigger.blender[N].stimulus[M] = eventID

+

+ + + + + + + + + + + + + + +

eventID

+

The event that triggers the blender action; see Details

+

N

+

An integer representing the trigger event blender (up to six)

+

M

+

An integer representing the stimulus index (1 to 4)

+
+

Details

+

There are four stimulus inputs that can each select a different event. The eventID parameter can be the event ID of any trigger event.

+

Use zero to disable the blender input.

+

The eventID parameter may be one of the existing trigger event IDs shown in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Example

+

+ + + + + + + + +

digio.trigger[3].mode = digio.TRIG_FALLING

+

digio.trigger[5].mode = digio.TRIG_FALLING

+

trigger.blender[1].orenable = true

+

trigger.blender[1].stimulus[1] = digio.trigger[3].EVENT_ID

+

trigger.blender[1].stimulus[2] = digio.trigger[5].EVENT_ID

+

Generate a trigger blender 1 event when a digital I/O trigger happens on line 3 or 5.

+
+

Also see

+

trigger.blender[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17688.htm b/WebHelpDocs/2601B-PULSE/17688.htm new file mode 100644 index 0000000..1a03116 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17688.htm @@ -0,0 +1,210 @@ + + + + + trigger.timer[N].stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.timer[N].stimulus

+

This attribute specifies which event starts the timer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup
Trigger timer N reset

+

Not saved

+

0

+
+

Usage

+

eventID = trigger.timer[N].stimulus

+

trigger.timer[N].stimulus = eventID

+

+ + + + + + + + + + +

eventID

+

The event that triggers the timer delay

+

N

+

Trigger timer number (1 to 8)

+
+

Details

+

The eventID parameter may be one of the trigger event IDs shown in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Set this attribute to the eventID of any trigger event to cause the timer to start when that event occurs.

+

Set this attribute to zero (0) to disable event processing.

+

Example

+

+ + + + + + +

print(trigger.timer[1].stimulus)

+

Prints the event that will start a trigger 1 timer action.

+
+

Also see

+

trigger.timer[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17691.htm b/WebHelpDocs/2601B-PULSE/17691.htm new file mode 100644 index 0000000..a362fe2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17691.htm @@ -0,0 +1,100 @@ + + + + + digio.trigger[N].pulsewidth + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].pulsewidth

+

This attribute describes the length of time that the trigger line is asserted for output triggers.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Digital I/O trigger N reset
Recall setup

+

Not saved

+

10e-6 (10 µs)

+
+

Usage

+

width = digio.trigger[N].pulsewidth

+

digio.trigger[N].pulsewidth = width

+

+ + + + + + + + + + +

width

+

The pulse width (seconds)

+

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

Setting the pulse width to zero (0) seconds asserts the trigger indefinitely. To release the trigger line, use digio.trigger[N].release().

+

Example

+

+ + + + + + +

digio.trigger[4].pulsewidth = 20e-6

+

Sets the pulse width for trigger line 4 to 20 μs.

+
+

Also see

+

digio.trigger[N].assert()

+

digio.trigger[N].reset()

+

digio.trigger[N].release()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17719.htm b/WebHelpDocs/2601B-PULSE/17719.htm new file mode 100644 index 0000000..74ebc37 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17719.htm @@ -0,0 +1,108 @@ + + + + + digio.trigger[N].reset() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].reset()

+

This function resets trigger values to their factory defaults.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

digio.trigger[N].reset()

+

+ + + + + + +

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

This function resets the following attributes to factory default settings:

+
  • digio.trigger[N].mode
  • digio.trigger[N].pulsewidth
  • digio.trigger[N].stimulus

It also clears digio.trigger[N].overrun.

+

Example

+

+ + + + + + + + +

digio.trigger[3].mode = 2

+

digio.trigger[3].pulsewidth = 50e-6

+

digio.trigger[3].stimulus = digio.trigger[5].EVENT_ID

+

print(digio.trigger[3].mode, digio.trigger[3].pulsewidth, digio.trigger[3].stimulus)

+

digio.trigger[3].reset()

+

print(digio.trigger[3].mode, digio.trigger[3].pulsewidth, digio.trigger[3].stimulus)

+

Set the digital I/O trigger line 3 for a falling edge with a pulsewidth of 50 µs.

+

Use digital I/O line 5 to trigger the event on line 3.

+

Reset the line back to factory default values.

+

Output before reset:

+

2.00000e+00 5.00000e-05 5.00000e+00

+

Output after reset:

+

0.00000e+00 1.00000e-05 0.00000e+00

+
+

Also see

+

digio.trigger[N].mode

+

digio.trigger[N].overrun

+

digio.trigger[N].pulsewidth

+

digio.trigger[N].stimulus

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17785.htm b/WebHelpDocs/2601B-PULSE/17785.htm new file mode 100644 index 0000000..305a063 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17785.htm @@ -0,0 +1,100 @@ + + + + + scriptVar.list() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

scriptVar.list()

+

This function generates a script listing.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

scriptVar.list()

+

+ + + + + + +

scriptVar

+

The name of the variable that references the script

+
+

Details

+

This function generates output in the form of a sequence of response messages (one message for each line of the script). It also generates output of the script control messages (loadscript or loadandrunscript and endscript).

+

Example

+

+ + + + + + + + +

test7 = script.new("display.clear() display.settext('Hello from my test')", "test7")

+

test7()

+

test7.save()

+

test7.list()

+

The above example code creates a script named test7 that displays text on the front panel and lists the script with the following output:

+

loadscript test7

+

display.clear() display.settext("Hello from my test")

+

endscript

+
+

Also see

+

Load a script by sending commands over the remote interface

+

Retrieve source code one line at a time

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17789.htm b/WebHelpDocs/2601B-PULSE/17789.htm new file mode 100644 index 0000000..bcd55ae --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17789.htm @@ -0,0 +1,44 @@ + + + + + Information on scripting and programming + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Information on scripting and programming

+

If you need information about using scripts with your TSP-enabled instrument, see Fundamentals of scripting for TSP.

+

If you need information about using the Lua programming language with the instrument, see Fundamentals of programming for TSP.

+ + + + +
+

See also

Introduction to TSP operation

Controlling the instrument by sending individual command messages

Queries

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17852.htm b/WebHelpDocs/2601B-PULSE/17852.htm new file mode 100644 index 0000000..f624f1f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17852.htm @@ -0,0 +1,49 @@ + + + + + Using the TSP command reference + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Using the TSP command reference

+

The Test Script Processor (TSP®) command reference contains detailed descriptions of each of the TSP commands that you can use to control your instrument. Each command description is broken into subsections. The figure below shows an example of a command description.

+

Example instrument command description

+

The subsections contain information about the command. The subsections are:

+
  • Command name and summary table
  • Usage
  • Details
  • Example
  • Also see

The content of each of these subsections is described in the following topics.

+ + + + + +
+

In this section

Command name and summary table

Command usage

Command details

Example section

Related commands and information

+

See also

TSP command reference

TSP command programming notes

TSP commands

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17853.htm b/WebHelpDocs/2601B-PULSE/17853.htm new file mode 100644 index 0000000..447ff89 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17853.htm @@ -0,0 +1,45 @@ + + + + + Command name and summary table + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Command name and summary table

+

Each instrument command description starts with the command name, followed by a brief description and a table with relevant information for each command. Definitions for the numbered items in the figure below are listed following the figure.

+

TSP command name and summary table

+
  1. Instrument command name. Indicates the beginning of the command description. It is followed by a brief description of what the command does.
  2. Type of command. Commands can be functions, attributes, or constants. If the command is an attribute, it can be read-only (R), read-write (RW), or write-only (W). For detail on commands, see Introduction to TSP operation.
  3. TSP-Link accessible. Yes or No; indicates whether or not the command can be accessed through a TSP-Link network.
  4. Affected by. Commands or actions that may change the setting of this command.
    • LAN restore defaults: This command is reset to the default value when lan.restoredefaults() is sent.
    • Digital I/O trigger N reset: This command is reset to the default value when digio.trigger[N].reset() is sent.
    • Recall setup: This command is stored as part of the saved setup and is changed to the value stored in the saved setup when the setup is recalled.
    • Instrument reset: This command is reset to the default value when reset(), localnode.reset(), or *RST is sent.
    • SMU reset: This command is reset to the default value when smua.reset() is sent.
    • Power cycle: This command is set to the default value when the instrument power is cycled.
  5. Where saved. Indicates where the command settings reside once they are used on an instrument. Options include:
    • Not saved: Command is not saved anywhere and must be typed each time you use it.
    • Nonvolatile memory: Storage area in the instrument where information is saved when the instrument is turned off.
    • Saved setup: Command is saved as part of the saved setup.
  6. Default value: Lists the default value or constant for the command. The parameter values are defined in the Usage or Details sections of the command description.
+ + + +
+

See also

Using the TSP command reference

Command usage

Command details

Example section

Related commands and information

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17854.htm b/WebHelpDocs/2601B-PULSE/17854.htm new file mode 100644 index 0000000..44f15ae --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17854.htm @@ -0,0 +1,47 @@ + + + + + Command usage + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Command usage

+

The Usage section of the remote command listing shows how to properly structure the command. Each line in the Usage section is a separate variation of the command usage. All possible command usage options are shown.

+

TSP usage description

+

1 Structure of command usage: Shows how the parts of the command should be organized. If a parameter is shown to the left of the command, it is the return when you print the command. Information to the right is the parameters or other items you need to enter when setting the command.

+

2 User-supplied parameters: Indicated by italics. For example, for the function beeper.beep(duration, frequency), replace duration with the number of seconds and frequency with the frequency of the tone. Send beeper.beep(2, 2400) to generate a two-second, 2400 Hz tone.

Some commands have optional parameters. If there are optional parameters, they must be entered in the order presented in the Usage section. You cannot leave out any parameters that precede the optional parameter. Optional parameters are shown as separate lines in usage, presented in the required order with each valid permutation of the optional parameters.
For example:
printbuffer(startIndex, endIndex, buffer1)
printbuffer(startIndex, endIndex, buffer1, buffer2)

+

3 Parameter value options: Descriptions of the options that are available for the user-defined parameter.

+ + + + +
+

See also

Using the TSP command reference

Command name and summary table

Command details

Example section

Related commands and information

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17855.htm b/WebHelpDocs/2601B-PULSE/17855.htm new file mode 100644 index 0000000..6989c6f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17855.htm @@ -0,0 +1,45 @@ + + + + + Command details + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Command details

+

This section lists additional information you need to know to successfully use the remote command.

+

+

TSP Details description

+ + + + +
+

See also

Using the TSP command reference

Command name and summary table

Command usage

Example section

Related commands and information

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17856.htm b/WebHelpDocs/2601B-PULSE/17856.htm new file mode 100644 index 0000000..3aa00d5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17856.htm @@ -0,0 +1,46 @@ + + + + + Example section + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Example section

+

The Example section of the remote command description shows examples of how you can use the command.

+

TSP example code

+

1 Actual example code that you can copy from this table and paste into your own programming application.

+

2 Description of the code and what it does. This may also contain example output of the code.

+ + + + +
+

See also

Using the TSP command reference

Command name and summary table

Command usage

Command details

Related commands and information

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17857.htm b/WebHelpDocs/2601B-PULSE/17857.htm new file mode 100644 index 0000000..c095d40 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17857.htm @@ -0,0 +1,44 @@ + + + + + Related commands and information + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Related commands and information

+

The Also see section of the remote command description lists additional commands or sections that are related to the command.

+

TSP Also see description

+ + + + +
+

See also

Using the TSP command reference

Command name and summary table

Command usage

Command details

Example section

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/17860.htm b/WebHelpDocs/2601B-PULSE/17860.htm new file mode 100644 index 0000000..7a535df --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/17860.htm @@ -0,0 +1,52 @@ + + + + + Syntax rules + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Syntax rules

+

Use these syntax requirements to build well-formed instrument control commands.

+

Instrument commands are case sensitive. Refer to the command reference descriptions for the correct case.

+

The white space in lists of parameters in functions is optional. For example, the following functions are equivalent:

+

digio.writebit(3,0)

+

digio.writebit (3, 0)

+

All functions must have a set of parentheses () immediately following the function, even if there are no parameters specified. For example:

+

waitcomplete(G)

+

timezone = localnode.gettimezone()

+

If there are multiple parameters, they must be separated by commas (,). For example:

+

beeper.beep(0.5, 2400)

+ + + + +
+

See also

TSP command programming notes

Placeholder text

Time and date values

Settings ignored when the pulser is enabled

Settings ignored when the pulser is disabled

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18551.htm b/WebHelpDocs/2601B-PULSE/18551.htm new file mode 100644 index 0000000..34b8ff7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18551.htm @@ -0,0 +1,101 @@ + + + + + bufferVar.fillcount + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.fillcount

+

This attribute sets the reading buffer fill count.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

See Details

+

0

+
+

Usage

+

fillCount = bufferVar.fillcount

+

bufferVar.fillcount = fillCount

+

+ + + + + + + + + + +

fillCount

+

The reading buffer fill count

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+
+

Details

+

The reading buffer fill count sets the number of readings to store before restarting at index 1. If the value is zero (0), then the capacity of the buffer is used. Use this attribute to control when the SMU restarts filling the buffer at index 1, rather than having it restart when the buffer is full.

+

If the bufferVar.fillcount attribute is set to a value higher than the capacity of the buffer, after storing the element at the end of the buffer, the SMU will overwrite the reading at index 1, the reading after that will overwrite the reading at index 2, and so on.

+

This attribute is only used when the bufferVar.fillmode attribute is set to smua.FILL_WINDOW.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example

+

+ + + + + + +

smua.nvbuffer1.fillcount = 50

+

Sets fill count of dedicated reading buffer 1 to 50.

+
+

Also see

+

bufferVar.fillmode

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18552.htm b/WebHelpDocs/2601B-PULSE/18552.htm new file mode 100644 index 0000000..e1e014f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18552.htm @@ -0,0 +1,103 @@ + + + + + bufferVar.fillmode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.fillmode

+

This attribute sets the reading buffer fill mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

See Details

+

0 (smua.FILL_ONCE)

+
+

Usage

+

fillMode = bufferVar.fillmode

+

bufferVar.fillmode = fillMode

+

+ + + + + + + + + + +

fillMode

+

The reading buffer fill mode; set to one of the following:

+
  • 0 or smua.FILL_ONCE: Do not overwrite old data
  • 1 or smua.FILL_WINDOW: New readings restart at index 1 after acquiring reading at index bufferVar.fillcount

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+
+

Details

+

When this attribute is set to smua.FILL_ONCE, the reading buffer will not overwrite readings. If the buffer fills up, new readings will be discarded.

+

When this attribute is set to smua.FILL_WINDOW, new readings will be added after existing data until the buffer holds bufferVar.fillcount elements. Continuing the sequence, the next reading will overwrite the reading at index 1, the reading after that will overwrite the reading at index 2, and so on.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example

+

+ + + + + + + + +

smua.nvbuffer1.fillmode = smua.FILL_ONCE

+

Sets fill mode of dedicated reading buffer 1 to fill once (do not overwrite old data).

+
+

Also see

+

bufferVar.fillcount

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18554.htm b/WebHelpDocs/2601B-PULSE/18554.htm new file mode 100644 index 0000000..a57be50 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18554.htm @@ -0,0 +1,233 @@ + + + + + smua.buffer.getstats() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.buffer.getstats()

+

This function returns the statistics for a specified reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

statistics = smua.buffer.getstats(bufferVar)

+

+ + + + + + + + + + +

statistics

+

The statistical data about the data in the reading buffer

+

bufferVar

+

The reading buffer to process

+
+

Details

+

This function returns a table with statistical data about the data that is placed in the buffer.

+

The SMU automatically updates reading buffer statistics as data is added to the reading buffer. When the reading buffer is configured to wrap around and overwrite older data with new data, the buffer statistics include the data that was overwritten.

+

The table returned from this function is a snapshot. Although the SMU continues to update the statistics, the table returned is not updated. To get fresh statistics, call this function again.

+

The statistics parameter has the attributes described in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

+

When returned

+

Description

+

n

+

Always

+

The number of data points on which the statistics are based

+

mean

+

When n > 0

+

The average of all readings added to the buffer

+

stddev

+

When n > 1

+

The standard deviation of all readings (samples) added to the buffer

+

min

+

When n > 0

+

A table containing data about the minimum reading value added to the buffer

+

max

+

When n > 0

+

A table containing data about the maximum reading value added to the buffer

+
+

If n equals zero (0), all other attributes are nil. If n equals 1, the stddev attribute is nil because the standard deviation of a sample size of 1 is undefined.

+

The min and max entries each have the attributes defined in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Attribute

+

Description

+

measurefunction

+

String indicating the function that was measured for the reading (current, voltage, ohms or watts)

+

measurerange

+

The full-scale range value for the measurement range used when the measurement was made

+

reading

+

The reading value

+

sourcefunction

+

String indicating the source function at the time of the measurement (current or voltage)

+

sourceoutputstate

+

String indicating the state of the source (off or on)

+

sourcerange

+

Full-scale range value for the source range used when the measurement was made

+

sourcevalue

+

If bufferVar.collectsourcevalues is enabled, the sourced value in effect at the time of the reading

+

status

+

Status value for the reading; the status value is a floating-point number that encodes the status value into a floating-point value

+

timestamp

+

If bufferVar.collecttimestamps is enabled, the timestamp, in seconds, between when the reading was acquired and when the first reading in the buffer was acquired; adding this value to the base timestamp will give the actual time the measurement was acquired

+
+

Example

+

+ + + + + + + + +

reset()

+

smua.nvbuffer1.clear()

+

smua.measure.count = 10

+

smua.measure.v(smua.nvbuffer1)

+

stats = smua.buffer.getstats(smua.nvbuffer1)

+

print("n= "..stats.n)

+

print("mean= "..stats.mean)

+

print("stddev= "..stats.stddev)

+

print("min= "..stats.min.reading)

+

print("max= "..stats.max.reading)

+

Make measurements and store them in nvbuffer1. Print the statistics for the data.

+

Example output:

+

n= 10

+

mean= -2.3851394871599e-05

+

stddev= 4.406545187484e-07

+

min= -2.4557113647461e-05

+

max= -2.322196996829e-05

+
+

Also see

+

smua.buffer.recalculatestats()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18556.htm b/WebHelpDocs/2601B-PULSE/18556.htm new file mode 100644 index 0000000..97ccc4a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18556.htm @@ -0,0 +1,94 @@ + + + + + smua.buffer.recalculatestats() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.buffer.recalculatestats()

+

This function recalculates the statistics of the specified reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.buffer.recalculatestats(bufferVar)

+

+ + + + + + +

bufferVar

+

The reading buffer to process

+
+

Details

+

This function causes the SMU to regenerate the reading buffer statistics about the specified reading buffer. Because the SMU automatically updates reading buffer statistics when data is added to the reading buffer, this function is generally not needed. When the reading buffer is configured to wrap around and overwrite older data with new data, the buffer statistics will include the data that was overwritten. Use this function to recalculate the statistics that include only the data that is presently stored in the buffer.

+

Example

+

+ + + + + + + + +

smua.buffer.recalculatestats(smua.nvbuffer1)

+

Recalculates the statistics of buffer smua.nvbuffer1.

+
+

Also see

+

bufferVar.fillmode

+

smua.buffer.getstats()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18560.htm b/WebHelpDocs/2601B-PULSE/18560.htm new file mode 100644 index 0000000..664f5f1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18560.htm @@ -0,0 +1,44 @@ + + + + + Analog-to-digital converter + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Analog-to-digital converter

+

The 2601B-PULSE SMUs have an integrating analog-to-digital converter (ADC). The integrating ADC uses a ratiometric analog-to-digital conversion technique. Depending on the configuration of the integrating ADC, periodic fresh reference measurements are required to minimize drift. The measurement aperture is used to determine the time interval between these measurement updates. For additional information, see Autozero. To help optimize operation of this ADC, the instrument caches the reference and zero values for up to ten of the most recent number of power line cycles. For additional information, see NPLC caching.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18832.htm b/WebHelpDocs/2601B-PULSE/18832.htm new file mode 100644 index 0000000..ae82360 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18832.htm @@ -0,0 +1,121 @@ + + + + + script.newautorun() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.newautorun()

+

This function creates a script and enables autorun.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

scriptVar = script.newautorun("code")

+

scriptVar = script.newautorun("code", "name")

+

+ + + + + + + + + + + + + + +

scriptVar

+

The name of the variable that will reference the script

+

code

+

A string that contains the body of the script

+

name

+

The name of the script

+
+

Details

+

The name parameter is the name that is added to the script.user.scripts table. If name is not given, an empty string is used, and the script is unnamed. If the name already exists in script.user.scripts, the existing script's name attribute is set to an empty string before it is replaced by the new script.

+

Note that name is the value that is used for the instrument front panel display. If this value is not defined, the script is not available from the front panel.

+

You must save the new script into nonvolatile memory to keep it when the instrument is turned off.

+

The script is run automatically immediately after it is created.

+

This command is the same as the script.new() function except that the script is automatically run.

+

Example

+

+ + + + + + + + +

NewAuto = script.newautorun("print('Hello from new auto run command')", 'NewAuto')

+

print(NewAuto.autorun)

+

print(NewAuto.name)

+

Creates a new script called NewAuto that automatically has the autorun attribute set to yes after it is created. The name is set to "NewAuto".

+

Output:

+

Hello from new auto run command

+

yes

+

NewAuto

+
+

Also see

+

Create a script using the script.new() command

+

Global variables and the script.user.scripts table

+

Named scripts

+

script.new()

+

scriptVar.autorun

+

scriptVar.save()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18833.htm b/WebHelpDocs/2601B-PULSE/18833.htm new file mode 100644 index 0000000..fe4da7d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18833.htm @@ -0,0 +1,82 @@ + + + + + script.run() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.run()

+

This function runs the anonymous script.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

script.run()

+

run()

+

Details

+

Each time the script.run() command is given, the anonymous script is executed. This script can be run using this command many times without having to re-send it.

+

Example

+

+ + + + + + +

run()

+

Runs the anonymous script.

+
+

Also see

+

script.anonymous

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/18841.htm b/WebHelpDocs/2601B-PULSE/18841.htm new file mode 100644 index 0000000..bdff2b6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/18841.htm @@ -0,0 +1,99 @@ + + + + + beeper.beep() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

beeper.beep()

+

This function generates an audible tone.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

beeper.beep(duration, frequency)

+

+ + + + + + + + + + +

duration

+

The amount of time to play the tone (0.001 s to 100 s)

+

frequency

+

The frequency of the tone in Hertz (Hz)

+
+

Details

+

You can use the beeper of the 2601B-PULSE to provide an audible signal at a specified frequency and time duration. For example, you can use the beeper to signal the end of a lengthy sweep.

+

The beeper will not sound if it is disabled. It can be disabled or enabled with the beeper enable command, or through the front panel.

+

Example

+

+ + + + + + +

beeper.enable = beeper.ON

+

beeper.beep(2, 2400)

+

Enables the beeper and generates a two-second, 2400 Hz tone.

+
+

Also see

+

beeper.enable

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19138.htm b/WebHelpDocs/2601B-PULSE/19138.htm new file mode 100644 index 0000000..fbc41d4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19138.htm @@ -0,0 +1,108 @@ + + + + + SweepVListMeasureI() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

SweepVListMeasureI()

+

This KISweep factory script function performs a voltage list sweep with current measured at every step (point).

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

SweepVListMeasureI(smua, vlist, stime, points)

+

+ + + + + + + + + + + + + + +

vlist

+

Arbitrary list of voltage source values; vlist = {value1, value2, ... valueN}

+

stime

+

Settling time in seconds; occurs after stepping the source and before making a measurement

+

points

+

Number of sweep points (must be >= 2)

+
+

Details

+

Data for current measurements, voltage source values, and timestamps are stored in smua.nvbuffer1.

+

If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.

+

Performs a voltage list sweep with current measured at every step (point):

+
  1. Sets the SMU to output vlist volts value, allows the source to settle for stime seconds, and then performs a current measurement.
  2. Sets the SMU to output the next vlist volts value, allows the source to settle for stime seconds, and then performs a current measurement.
  3. Repeats the above sequence until the current is measured for the last volts value. The last point in the list to be measured is points.

Example

+

+ + + + + + + + +

myvlist = {-0.1, 0.1, -1, 1, -6, 6, -40, 40, 0, 0}

+

SweepVListMeasureI(smua, myvlist, 500E-3, 10)

+

This function performs a 10-point voltage list sweep starting at the first point in myvlist. Current is measured at every step (point) in the sweep. The source will be allowed to settle on each step for 500 ms before a measurement is performed.

+
+

Also see

+

KISweep factory script

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19382.htm b/WebHelpDocs/2601B-PULSE/19382.htm new file mode 100644 index 0000000..5f9b721 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19382.htm @@ -0,0 +1,139 @@ + + + + + display.loadmenu.add() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.loadmenu.add()

+

This function adds an entry to the USER menu, which can be accessed by pressing the LOAD key on the front panel.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.loadmenu.add("displayName", "code")

+

display.loadmenu.add("displayName", "code", memory)

+

+ + + + + + + + + + + + + + +

displayName

+

The name that is added to the USER menu

+

code

+

The code that is run from the USER menu

+

memory

+

Determines if code is saved to nonvolatile memory:

+
  • 0 or display.DONT_SAVE: Does not save the code to nonvolatile memory
  • 1 or display.SAVE: Saves the code to nonvolatile memory (default)
+

Details

+

After adding code to the load menu, you can run it from the front panel by pressing the LOAD key, then selecting USER to select from the available code to load. Pressing the RUN key will then run the script.

+

You can add items in any order. They are always displayed in alphabetic order when the menu is selected.

+

Any Lua code can be included in the code parameter. If memory is set to display.SAVE, the entry (name and code) is saved in nonvolatile memory. Scripts, functions, and variables used in the code are not saved by display.SAVE. Functions and variables need to be saved with the code. If the code is not saved in nonvolatile memory, it is lost when the 2601B-PULSE is turned off. See Example 2 below.

+

If you do not make a selection for memory, the code is automatically saved to nonvolatile memory.

+

VARIABLE - NOTE
You can create a script that defines several functions, and then use the display.loadmenu.add() command to add items that call those individual functions. This allows the operator to run tests from the front panel.

+

Example 1

+

+ + + + + + + + +

display.loadmenu.add("Test9", "Test9()")

+

Assume a user script named "Test9" has been loaded into the runtime environment. Adds the menu entry to the USER menu to run the script after loading.

+
+

Example 2

+

+ + + + + + + + +

display.loadmenu.add("Test", "DUT1() beeper.beep(2, 500)", display.SAVE)

+

Assume a script with a function named “DUT1” has already been loaded into the instrument, and the script has not been saved in nonvolatile memory.

+

Now assume you want to add a test named “Test” to the USER menu. You want the test to run the function named “DUT1” and sound the beeper. This example adds “Test” to the menu, defines the code, and then saves the displayName and code in nonvolatile memory.

+

When “Test” is run from the front panel USER menu, the function named “DUT1” executes and the beeper beeps for two seconds.

+

Now assume you turn off instrument power. Because the script was not saved in nonvolatile memory, the function named “DUT1” is lost when you turn the instrument on. When “Test” is again run from the front panel, an error is generated because DUT1 no longer exists in the instrument as a function.

+
+

Example 3

+

+ + + + + + + + +

display.loadmenu.add("Part1", "testpart([[Part1]], 5.0)", display.SAVE)

+

Adds an entry called “Part1” to the front panel USER load menu for the code testpart([[Part1]], 5.0), and saves it in nonvolatile memory.

+
+

Also see

+

display.loadmenu.delete()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19389.htm b/WebHelpDocs/2601B-PULSE/19389.htm new file mode 100644 index 0000000..35e0a8f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19389.htm @@ -0,0 +1,46 @@ + + + + + TSP commands + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP commands

+

The TSP commands available for the instrument are listed in alphabetic order.

+ + + + + +
+

In this section

beeper.beep()

beeper.enable

bit.bitand()

bit.bitor()

bit.bitxor()

bit.clear()

bit.get()

bit.getfield()

bit.set()

bit.setfield()

bit.test()

bit.toggle()

bufferVar.appendmode

bufferVar.basetimestamp

bufferVar.cachemode

bufferVar.capacity

bufferVar.clear()

bufferVar.clearcache()

bufferVar.collectsourcevalues

bufferVar.collecttimestamps

bufferVar.fillcount

bufferVar.fillmode

bufferVar.measurefunctions

bufferVar.measureranges

bufferVar.n

bufferVar.readings

bufferVar.sourcefunctions

bufferVar.sourceoutputstates

bufferVar.sourceranges

bufferVar.sourcevalues

bufferVar.statuses

bufferVar.timestampresolution

bufferVar.timestamps

dataqueue.add()

dataqueue.CAPACITY

dataqueue.clear()

dataqueue.count

dataqueue.next()

delay()

digio.readbit()

digio.readport()

digio.trigger[N].assert()

digio.trigger[N].clear()

digio.trigger[N].EVENT_ID

digio.trigger[N].mode

digio.trigger[N].overrun

digio.trigger[N].pulsewidth

digio.trigger[N].release()

digio.trigger[N].reset()

digio.trigger[N].stimulus

digio.trigger[N].wait()

digio.writebit()

digio.writeport()

digio.writeprotect

display.clear()

display.getannunciators()

display.getcursor()

display.getlastkey()

display.gettext()

display.inputvalue()

display.loadmenu.add()

display.loadmenu.catalog()

display.loadmenu.delete()

display.locallockout

display.menu()

display.numpad

display.prompt()

display.screen

display.sendkey()

display.smua.digits

display.setcursor()

display.settext()

display.smua.limit.func

display.smua.measure.func

display.trigger.clear()

display.trigger.EVENT_ID

display.trigger.overrun

display.trigger.wait()

display.waitkey()

errorqueue.clear()

errorqueue.count

errorqueue.next()

eventlog.all()

eventlog.clear()

eventlog.count

eventlog.enable

eventlog.next()

eventlog.overwritemethod

exit()

fileVar:close()

fileVar:flush()

fileVar:read()

fileVar:seek()

fileVar:write()

format.asciiprecision

format.byteorder

format.data

fs.chdir()

fs.cwd()

fs.is_dir()

fs.is_file()

fs.mkdir()

fs.readdir()

fs.rmdir()

gettimezone()

gm_isweep()

gm_vsweep()

gpib.address

i_leakage_measure()

i_leakage_threshold()

io.close()

io.flush()

io.input()

io.open()

io.output()

io.read()

io.type()

io.write()

lan.applysettings()

lan.autoconnect

lan.config.dns.address[N]

lan.config.dns.domain

lan.config.dns.dynamic

lan.config.dns.hostname

lan.config.dns.verify

lan.config.duplex

lan.config.gateway

lan.config.ipaddress

lan.config.method

lan.config.speed

lan.config.subnetmask

lan.linktimeout

lan.lxidomain

lan.nagle

lan.reset()

lan.restoredefaults()

lan.status.dns.address[N]

lan.status.dns.name

lan.status.duplex

lan.status.gateway

lan.status.ipaddress

lan.status.macaddress

lan.status.port.dst

lan.status.port.rawsocket

lan.status.port.telnet

lan.status.port.vxi11

lan.status.speed

lan.status.subnetmask

lan.timedwait

lan.trigger[N].assert()

lan.trigger[N].clear()

lan.trigger[N].connect()

lan.trigger[N].connected

lan.trigger[N].disconnect()

lan.trigger[N].EVENT_ID

lan.trigger[N].ipaddress

lan.trigger[N].mode

lan.trigger[N].overrun

lan.trigger[N].protocol

lan.trigger[N].pseudostate

lan.trigger[N].stimulus

lan.trigger[N].wait()

localnode.autolinefreq

localnode.description

localnode.license

localnode.linefreq

localnode.model

localnode.password

localnode.passwordmode

localnode.prompts

localnode.prompts4882

localnode.reset()

localnode.revision

localnode.serialno

localnode.showerrors

makegetter()

makesetter()

meminfo()

node[N].execute()

node[N].getglobal()

node[N].setglobal()

opc()

os.remove()

os.rename()

os.time()

print()

printbuffer()

printnumber()

reset()

savebuffer()

script.anonymous

script.delete()

script.factory.catalog()

script.load()

script.new()

script.newautorun()

script.restore()

script.run()

script.user.catalog()

scriptVar.autorun

scriptVar.list()

scriptVar.name

scriptVar.run()

scriptVar.save()

scriptVar.source

serial.baud

serial.databits

serial.flowcontrol

serial.parity

serial.read()

serial.write()

settime()

settimezone()

setup.poweron

setup.recall()

setup.save()

smua.abort()

smua.buffer.getstats()

smua.buffer.recalculatestats()

smua.cal.adjustdate

smua.cal.date

smua.cal.due

smua.cal.lock()

smua.cal.password

smua.cal.polarity

smua.cal.restore()

smua.cal.save()

smua.cal.state

smua.cal.unlock()

smua.contact.calibratehi()

smua.contact.calibratelo()

smua.contact.check()

smua.contact.r()

smua.contact.speed

smua.contact.threshold

smua.interlock.enable

smua.makebuffer()

smua.measure.autorangeY

smua.measure.autozero

smua.measure.calibrateY()

smua.measure.count

smua.measure.delay

smua.measure.delayfactor

smua.measure.filter.count

smua.measure.filter.enable

smua.measure.filter.type

smua.measure.highcrangedelayfactor

smua.measure.interval

smua.measure.lowrangeY

smua.measure.nplc

smua.measure.overlappedY()

smua.measure.rangeY

smua.measure.rel.enableY

smua.measure.rel.levelY

smua.measure.Y()

smua.measureYandstep()

smua.nvbufferY

smua.pulser.enable

smua.pulser.measure.aperture

smua.pulser.measure.calibrateY()

smua.pulser.measure.delay

smua.pulser.protect.sensev

smua.pulser.protect.sourcev

smua.pulser.protect.tripped

smua.pulser.rangeY

smua.pulser.source.calibratebiasi()

smua.pulser.source.calibratei()

smua.reset()

smua.savebuffer()

smua.sense

smua.source.autorangeY

smua.source.calibrateY()

smua.source.compliance

smua.source.delay

smua.source.func

smua.source.highc

smua.source.levelY

smua.source.limitY

smua.source.lowrangeY

smua.source.offfunc

smua.source.offlimitY

smua.source.offmode

smua.source.output

smua.source.rangeY

smua.source.settling

smua.source.sink

smua.trigger.arm.count

smua.trigger.arm.set()

smua.trigger.arm.stimulus

smua.trigger.ARMED_EVENT_ID

smua.trigger.autoclear

smua.trigger.count

smua.trigger.endpulse.action

smua.trigger.endpulse.set()

smua.trigger.endpulse.stimulus

smua.trigger.endsweep.action

smua.trigger.IDLE_EVENT_ID

smua.trigger.initiate()

smua.trigger.measure.action

smua.trigger.measure.set()

smua.trigger.measure.stimulus

smua.trigger.measure.Y()

smua.trigger.MEASURE_COMPLETE_EVENT_ID

smua.trigger.PULSE_COMPLETE_EVENT_ID

smua.trigger.source.action

smua.trigger.source.limitY

smua.trigger.source.linearY()

smua.trigger.source.listY()

smua.trigger.source.logY()

smua.trigger.source.pulsewidth

smua.trigger.source.set()

smua.trigger.source.stimulus

smua.trigger.SOURCE_COMPLETE_EVENT_ID

smua.trigger.SWEEP_COMPLETE_EVENT_ID

smua.trigger.SWEEPING_EVENT_ID

status.condition

status.measurement.*

status.measurement.buffer_available.*

status.measurement.current_limit.*

status.measurement.instrument.*

status.measurement.instrument.smua.*

status.measurement.protection.*

status.measurement.reading_overflow.*

status.measurement.voltage_limit.*

status.node_enable

status.node_event

status.operation.*

status.operation.calibrating.*

status.operation.instrument.*

status.operation.instrument.digio.*

status.operation.instrument.digio.trigger_overrun.*

status.operation.instrument.lan.*

status.operation.instrument.lan.trigger_overrun.*

status.operation.instrument.smua.*

status.operation.instrument.smua.trigger_overrrun.*

status.operation.instrument.trigger_blender.*

status.operation.instrument.trigger_blender.trigger_overrun.*

status.operation.instrument.trigger_timer.*

status.operation.instrument.trigger_timer.trigger_overrun.*

status.operation.instrument.tsplink.*

status.operation.instrument.tsplink.trigger_overrun.*

status.operation.measuring.*

status.operation.remote.*

status.operation.sweeping.*

status.operation.trigger_overrun.*

status.operation.user.*

status.questionable.*

status.questionable.calibration.*

status.questionable.instrument.*

status.questionable.instrument.smua.*

status.questionable.over_temperature.*

status.questionable.unstable_output.*

status.request_enable

status.request_event

status.reset()

status.standard.*

status.system.*

status.system2.*

status.system3.*

status.system4.*

status.system5.*

SweepILinMeasureV()

SweepIListMeasureV()

SweepILogMeasureV()

SweepVLinMeasureI()

SweepVListMeasureI()

SweepVLogMeasureI()

timer.measure.t()

timer.reset()

trigger.blender[N].clear()

trigger.blender[N].EVENT_ID

trigger.blender[N].orenable

trigger.blender[N].overrun

trigger.blender[N].reset()

trigger.blender[N].stimulus[M]

trigger.blender[N].wait()

trigger.clear()

trigger.EVENT_ID

trigger.generator[N].assert()

trigger.generator[N].EVENT_ID

trigger.timer[N].clear()

trigger.timer[N].count

trigger.timer[N].delay

trigger.timer[N].delaylist

trigger.timer[N].EVENT_ID

trigger.timer[N].overrun

trigger.timer[N].passthrough

trigger.timer[N].reset()

trigger.timer[N].stimulus

trigger.timer[N].wait()

trigger.wait()

tsplink.group

tsplink.master

tsplink.node

tsplink.readbit()

tsplink.readport()

tsplink.reset()

tsplink.state

tsplink.trigger[N].assert()

tsplink.trigger[N].clear()

tsplink.trigger[N].EVENT_ID

tsplink.trigger[N].mode

tsplink.trigger[N].overrun

tsplink.trigger[N].pulsewidth

tsplink.trigger[N].release()

tsplink.trigger[N].reset()

tsplink.trigger[N].stimulus

tsplink.trigger[N].wait()

tsplink.writebit()

tsplink.writeport()

tsplink.writeprotect

tspnet.clear()

tspnet.connect()

tspnet.disconnect()

tspnet.execute()

tspnet.idn()

tspnet.read()

tspnet.readavailable()

tspnet.reset()

tspnet.termination()

tspnet.timeout

tspnet.tsp.abort()

tspnet.tsp.abortonconnect

tspnet.tsp.rbtablecopy()

tspnet.tsp.runscript()

tspnet.write()

userstring.add()

userstring.catalog()

userstring.delete()

userstring.get()

waitcomplete()

+

See also

TSP command reference

TSP command programming notes

Using the TSP command reference

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19423.htm b/WebHelpDocs/2601B-PULSE/19423.htm new file mode 100644 index 0000000..4edf3fb --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19423.htm @@ -0,0 +1,48 @@ + + + + + Instrument identification + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Instrument identification

+

These commands store strings that describe the instrument.

+

localnode.description

+

localnode.model

+

localnode.revision

+

localnode.serialno

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19424.htm b/WebHelpDocs/2601B-PULSE/19424.htm new file mode 100644 index 0000000..8cb63a0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19424.htm @@ -0,0 +1,52 @@ + + + + + Miscellaneous + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Miscellaneous

+

delay()

+

exit()

+

localnode.autolinefreq

+

localnode.linefreq

+

makegetter()

+

makesetter()

+

meminfo()

+

opc()

+

waitcomplete()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19425.htm b/WebHelpDocs/2601B-PULSE/19425.htm new file mode 100644 index 0000000..c49744e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19425.htm @@ -0,0 +1,54 @@ + + + + + Parallel script execution + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Parallel script execution

+

dataqueue.add()

+

dataqueue.CAPACITY

+

dataqueue.clear()

+

dataqueue.count

+

dataqueue.next()

+

node[N].execute()

+

node[N].getglobal()

+

node[N].setglobal()

+

tsplink.group

+

tsplink.master

+

tsplink.node

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19432.htm b/WebHelpDocs/2601B-PULSE/19432.htm new file mode 100644 index 0000000..ad9a6ac --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19432.htm @@ -0,0 +1,54 @@ + + + + + Time + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Time

+

bufferVar.basetimestamp

+

bufferVar.collecttimestamps

+

bufferVar.timestampresolution

+

bufferVar.timestamps

+

delay()

+

gettimezone()

+

os.time()

+

settime()

+

settimezone()

+

timer.measure.t()

+

timer.reset()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19516.htm b/WebHelpDocs/2601B-PULSE/19516.htm new file mode 100644 index 0000000..bfdf5f2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19516.htm @@ -0,0 +1,47 @@ + + + + + Saved setups + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Saved setups

+

Use the saved setups commands to save or restore the configurations to or from the nonvolatile memory of the instrument or an installed USB flash drive. You can use the setup.poweron attribute to specify which setup is recalled when the instrument is turned on.

+

setup.poweron

+

setup.recall()

+

setup.save()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19536.htm b/WebHelpDocs/2601B-PULSE/19536.htm new file mode 100644 index 0000000..949bd17 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19536.htm @@ -0,0 +1,46 @@ + + + + + TSP command programming notes + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP command programming notes

+

This section contains general information about using TSP commands.

+ + + + + +
+

In this section

Placeholder text

Syntax rules

Time and date values

Settings ignored when the pulser is enabled

Settings ignored when the pulser is disabled

+

See also

TSP command reference

Using the TSP command reference

TSP commands

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19550.htm b/WebHelpDocs/2601B-PULSE/19550.htm new file mode 100644 index 0000000..9ef0d18 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19550.htm @@ -0,0 +1,44 @@ + + + + + Sweep operation + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Sweep operation

+

See the "Sweep operation" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19551.htm b/WebHelpDocs/2601B-PULSE/19551.htm new file mode 100644 index 0000000..5483662 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19551.htm @@ -0,0 +1,44 @@ + + + + + Status model + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Status model

+

See the "Status Model" topic in the Model 2601B-PULSE Reference Manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19552.htm b/WebHelpDocs/2601B-PULSE/19552.htm new file mode 100644 index 0000000..3d1dd34 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19552.htm @@ -0,0 +1,44 @@ + + + + + Queues + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Queues

+

See the "Queues" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19553.htm b/WebHelpDocs/2601B-PULSE/19553.htm new file mode 100644 index 0000000..062b894 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19553.htm @@ -0,0 +1,44 @@ + + + + + Digital I/O + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Digital I/O

+

See the "Digital I/O" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19554.htm b/WebHelpDocs/2601B-PULSE/19554.htm new file mode 100644 index 0000000..613e146 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19554.htm @@ -0,0 +1,44 @@ + + + + + TSP-Link + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP-Link

+

See the "TSP-Link" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19555.htm b/WebHelpDocs/2601B-PULSE/19555.htm new file mode 100644 index 0000000..06e9fce --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19555.htm @@ -0,0 +1,44 @@ + + + + + TSP advanced features + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP advanced features

+

See the "TSP advanced features" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19556.htm b/WebHelpDocs/2601B-PULSE/19556.htm new file mode 100644 index 0000000..05e0c40 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19556.htm @@ -0,0 +1,44 @@ + + + + + Create a script using the script.new() command + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Create a script using the script.new() command

+

See the "Create a script using the script.new() command" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19557.htm b/WebHelpDocs/2601B-PULSE/19557.htm new file mode 100644 index 0000000..db72dd1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19557.htm @@ -0,0 +1,44 @@ + + + + + Global variables and the script.user.scripts table + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Global variables and the script.user.scripts table

+

See the "Global variables and the script.user.scripts table" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19558.htm b/WebHelpDocs/2601B-PULSE/19558.htm new file mode 100644 index 0000000..3d1a747 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19558.htm @@ -0,0 +1,44 @@ + + + + + Named scripts + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Named scripts

+

See the "Named scripts" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19559.htm b/WebHelpDocs/2601B-PULSE/19559.htm new file mode 100644 index 0000000..c170623 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19559.htm @@ -0,0 +1,44 @@ + + + + + Load a script by sending commands over the remote interface + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Load a script by sending commands over the remote interface

+

See the "Load a script by sending commands over the remote interface" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19560.htm b/WebHelpDocs/2601B-PULSE/19560.htm new file mode 100644 index 0000000..2f0761f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19560.htm @@ -0,0 +1,44 @@ + + + + + Rename a script + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Rename a script

+

See the "Rename a script" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19561.htm b/WebHelpDocs/2601B-PULSE/19561.htm new file mode 100644 index 0000000..943f10a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19561.htm @@ -0,0 +1,44 @@ + + + + + RS-232 interface operation + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

RS-232 interface operation

+

See the "RS-232 interface operation" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19562.htm b/WebHelpDocs/2601B-PULSE/19562.htm new file mode 100644 index 0000000..1884894 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19562.htm @@ -0,0 +1,44 @@ + + + + + Saved setups + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Saved setups

+

See the "Saved setups" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19563.htm b/WebHelpDocs/2601B-PULSE/19563.htm new file mode 100644 index 0000000..4a70f53 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19563.htm @@ -0,0 +1,44 @@ + + + + + Adjustment + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Adjustment

+

See the "Adjustment" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19564.htm b/WebHelpDocs/2601B-PULSE/19564.htm new file mode 100644 index 0000000..7d824d6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19564.htm @@ -0,0 +1,44 @@ + + + + + Contact check connections + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Contact check connections

+

See the "Contact check connections" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19565.htm b/WebHelpDocs/2601B-PULSE/19565.htm new file mode 100644 index 0000000..7653eb6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19565.htm @@ -0,0 +1,44 @@ + + + + + Contact check measurements + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Contact check measurements

+

See the "Contact check measurements" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19566.htm b/WebHelpDocs/2601B-PULSE/19566.htm new file mode 100644 index 0000000..7676f20 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19566.htm @@ -0,0 +1,44 @@ + + + + + High-capacitance mode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

High-capacitance mode

+

See the "High-capacitance mode" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19567.htm b/WebHelpDocs/2601B-PULSE/19567.htm new file mode 100644 index 0000000..9deb462 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19567.htm @@ -0,0 +1,44 @@ + + + + + Configuring and running sweeps + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Configuring and running sweeps

+

See the "Configuring and running sweeps" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19568.htm b/WebHelpDocs/2601B-PULSE/19568.htm new file mode 100644 index 0000000..580787e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19568.htm @@ -0,0 +1,44 @@ + + + + + 2-wire local sensing connections + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

2-wire local sensing connections

+

See the "2-wire local sensing connections" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19569.htm b/WebHelpDocs/2601B-PULSE/19569.htm new file mode 100644 index 0000000..a140317 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19569.htm @@ -0,0 +1,44 @@ + + + + + 4-wire remote sensing connections + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

4-wire remote sensing connections

+

See the "4-wire remote sensing connections" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19570.htm b/WebHelpDocs/2601B-PULSE/19570.htm new file mode 100644 index 0000000..9ae5192 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19570.htm @@ -0,0 +1,44 @@ + + + + + Calibration + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Calibration

+

See the "Calibration" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19571.htm b/WebHelpDocs/2601B-PULSE/19571.htm new file mode 100644 index 0000000..a135735 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19571.htm @@ -0,0 +1,44 @@ + + + + + Measurement event registers + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Measurement event registers

+

See the "Measurement event registers" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19572.htm b/WebHelpDocs/2601B-PULSE/19572.htm new file mode 100644 index 0000000..7452ee4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19572.htm @@ -0,0 +1,44 @@ + + + + + Source-measure concepts + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Source-measure concepts

+

See the "Source-measure concepts" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19573.htm b/WebHelpDocs/2601B-PULSE/19573.htm new file mode 100644 index 0000000..8a04e5c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19573.htm @@ -0,0 +1,44 @@ + + + + + DUT test connections + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

DUT test connections

+

See the "DUT test connections" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19574.htm b/WebHelpDocs/2601B-PULSE/19574.htm new file mode 100644 index 0000000..04cedae --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19574.htm @@ -0,0 +1,44 @@ + + + + + Triggering + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Triggering

+

See the "Triggering" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19575.htm b/WebHelpDocs/2601B-PULSE/19575.htm new file mode 100644 index 0000000..3c09f89 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19575.htm @@ -0,0 +1,44 @@ + + + + + Status model overview + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Status model overview

+

See the "Status model overview" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19576.htm b/WebHelpDocs/2601B-PULSE/19576.htm new file mode 100644 index 0000000..fe948df --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19576.htm @@ -0,0 +1,44 @@ + + + + + Status byte and service request (SRQ) + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Status byte and service request (SRQ)

+

See the "Status byte and service request (SRQ)" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19578.htm b/WebHelpDocs/2601B-PULSE/19578.htm new file mode 100644 index 0000000..9fdc52a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19578.htm @@ -0,0 +1,44 @@ + + + + + Operation Status Registers + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Operation Status Registers

+

See the "Operation Status Registers" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19579.htm b/WebHelpDocs/2601B-PULSE/19579.htm new file mode 100644 index 0000000..566da68 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19579.htm @@ -0,0 +1,44 @@ + + + + + Questionable Status Registers + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Questionable Status Registers

+

See the "Questionable Status Registers" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19580.htm b/WebHelpDocs/2601B-PULSE/19580.htm new file mode 100644 index 0000000..fbb0802 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19580.htm @@ -0,0 +1,44 @@ + + + + + Standard Event Register + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Standard Event Register

+

See the "Standard Event Register" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19581.htm b/WebHelpDocs/2601B-PULSE/19581.htm new file mode 100644 index 0000000..c09ace4 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19581.htm @@ -0,0 +1,44 @@ + + + + + System summary and standard event registers + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

System summary and standard event registers

+

See the "System summary and standard event registers" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19582.htm b/WebHelpDocs/2601B-PULSE/19582.htm new file mode 100644 index 0000000..e533d66 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19582.htm @@ -0,0 +1,45 @@ + + + + + Additional information + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Additional information

+ + + + + +
+

In this section

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+

See also

Additional 2601B-PULSE information

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19632.htm b/WebHelpDocs/2601B-PULSE/19632.htm new file mode 100644 index 0000000..3cca012 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19632.htm @@ -0,0 +1,45 @@ + + + + + Measure auto delay + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Measure auto delay

+

The measure delay is a specific delay that is applied before each measurement is made. This delay is disabled by default (measurements are made immediately). You can change the default delay by setting the smua.measure.delay attribute either to a specific value or to an auto delay setting (set smua.measure.delay = smua.DELAY_AUTO). If the measure delay is set to the auto delay setting, a range-dependent delay is applied each time the instrument performs a current measurement. This delay also happens for the measurement that is taken after changing current ranges during an autoranged measurement. The default measurement delay varies by model.

+

You can increase or decrease the auto delay by changing the delay factor (for example, to reduce the delay across all ranges by half, set smua.measure.delayfactor = 0.5). For additional information, refer to smua.measure.delayfactor in the "Remote commands" section.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19914.htm b/WebHelpDocs/2601B-PULSE/19914.htm new file mode 100644 index 0000000..a3f7321 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19914.htm @@ -0,0 +1,130 @@ + + + + + bufferVar.measurefunctions + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.measurefunctions

+

This attribute contains the measurement function that was used to acquire a reading stored in a specified reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

measurefunction = bufferVar.measurefunctions[N]

+

+ + + + + + + + + + + + + + +

measurefunction

+

The measurement function used (Current, Voltage, Ohms, or Watts) to acquire reading number N in the specified buffer

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+

N

+

The reading number (1 to bufferVar.n)

+
+

Details

+

The measurefunctions buffer recall attribute is like an array (a Lua table) of strings indicating the function measured for the reading.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example 1

+

+ + + + + + + + +

measurefunction = smua.nvbuffer1.measurefunctions[5]

+

Store the measure function used to make reading number 5.

+
+

Example 2

+

+ + + + + + + + +

printbuffer(1, 5, smua.nvbuffer1.measurefunctions)

+

Print the measurement function that was used to measure the first five readings saved in dedicated reading buffer 1.

+

Example output:

+

Current, Current, Current, Current, Current

+
+

Also see

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19915.htm b/WebHelpDocs/2601B-PULSE/19915.htm new file mode 100644 index 0000000..0fcaa88 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19915.htm @@ -0,0 +1,130 @@ + + + + + bufferVar.measureranges + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.measureranges

+

This attribute contains the measurement range values that were used for readings stored in a specified buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

measurerange = bufferVar.measureranges[N]

+

+ + + + + + + + + + + + + + +

measurerange

+

The measurement range used to acquire reading number N in the specified buffer

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+

N

+

The reading number (1 to bufferVar.n)

+
+

Details

+

The measureranges buffer recall attribute is like an array (a Lua table) of full-scale range values for the measure range used when the measurement was made.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example 1

+

+ + + + + + + + +

measurerange = smua.nvbuffer1.measureranges[1]

+

Store the measure range that was used to make reading number 1.

+
+

Example 2

+

+ + + + + + + + +

printbuffer(1, 10, smua.nvbuffer1.measureranges)

+

Print the range values that were used for the first 10 readings saved in dedicated reading buffer 1.

+

Example output:

+

1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07

+
+

Also see

+

bufferVar.measurefunctions

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19916.htm b/WebHelpDocs/2601B-PULSE/19916.htm new file mode 100644 index 0000000..cbd1262 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19916.htm @@ -0,0 +1,129 @@ + + + + + bufferVar.sourcefunctions + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.sourcefunctions

+

This attribute contains the source function that was being used when the readings were stored in a specified reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

sourcefunction = bufferVar.sourcefunctions[N]

+

+ + + + + + + + + + + + + + +

sourcefunction

+

The source function used (Current or Voltage) to acquire reading number N in the specified buffer

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+

N

+

The reading number (1 to bufferVar.n)

+
+

Details

+

The sourcefunctions buffer recall attribute is like an array (a Lua table) of strings indicating the source function at the time of the measurement.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example 1

+

+ + + + + + +

sourcefunction = smua.nvbuffer1.sourcefunctions[3]

+

print(sourcefunction)

+

Store the source function used to make reading number 3 and output the value.

+
+

Example 2

+

+ + + + + + +

printbuffer(1, 10, smua.nvbuffer1.sourcefunctions)

+

 

+

 

+

Print the source function used for 10 readings stored in dedicated reading buffer 1.

+

Example output:

+

Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage

+
+

Also see

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19917.htm b/WebHelpDocs/2601B-PULSE/19917.htm new file mode 100644 index 0000000..0c08774 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19917.htm @@ -0,0 +1,115 @@ + + + + + bufferVar.sourceoutputstates + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.sourceoutputstates

+

This attribute indicates the state of the source output for readings that are stored in a specified buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

state = bufferVar.sourceoutputstates[N]

+

+ + + + + + + + + + + + + + +

state

+

The output state (Off or On) when reading N of the specified buffer was acquired

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+

N

+

The reading number (1 to bufferVar.n)

+
+

Details

+

The sourceoutputstates buffer recall attribute is similar to an array (a Lua table) of strings. This array indicates the state of the source output (Off or On) at the time of the measurement.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example

+

+ + + + + + +

printbuffer(1, 1, smua.nvbuffer1.sourceoutputstates)

+

Print the source output for the first reading stored in dedicated reading buffer 1.

+

Example output:

+

On

+
+

Also see

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19918.htm b/WebHelpDocs/2601B-PULSE/19918.htm new file mode 100644 index 0000000..4c69c6e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19918.htm @@ -0,0 +1,127 @@ + + + + + bufferVar.sourceranges + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.sourceranges

+

This attribute contains the source range that was used for readings stored in a specified reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

sourcerange = bufferVar.sourceranges[N]

+

+ + + + + + + + + + + + + + +

sourcerange

+

The source range used to acquire reading number N in the specified buffer

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+

N

+

The reading number (1 to bufferVar.n)

+
+

Details

+

The sourceranges buffer recall attribute is like an array (a Lua table) of full-scale range values for the source range used when the measurement was made.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example 1

+

+ + + + + + +

sourcerange = smua.nvbuffer1.sourceranges[1]

+

 

+

Store the source range that was used for the first reading stored in dedicated reading buffer 1.

+
+

Example 2

+

+ + + + + + +

printbuffer(1, 6, smua.nvbuffer1.sourceranges)

+

Print the source ranges that were used for the first 6 readings stored in source-measure unit (SMU) A, buffer 1.

+

Example output:

+

1.00000e-04, 1.00000e-04, 1.00000e-04, 1.00000e-04, 1.00000e-04, 1.00000e-04

+
+

Also see

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19919.htm b/WebHelpDocs/2601B-PULSE/19919.htm new file mode 100644 index 0000000..535243c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19919.htm @@ -0,0 +1,129 @@ + + + + + bufferVar.sourcevalues + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.sourcevalues

+

When enabled by the bufferVar.collectsourcevalues attribute, this attribute contains the source levels being output when readings in the reading buffer were acquired.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

sourcevalue = bufferVar.sourcevalues[N]

+

+ + + + + + + + + + + + + + +

sourcevalue

+

The output value of the source when reading N of the specified buffer was acquired

+

bufferVar

+

The reading buffer; can be a dynamically allocated buffer (user-defined), or a dedicated reading buffer (such as smua.nvbuffer1)

+

N

+

The reading number (1 to bufferVar.n)

+
+

Details

+

If the bufferVar.collectsourcevalues attribute is enabled before readings are taken, the bufferVar.sourcevalues buffer recall attribute is like an array (a Lua table) of the sourced value in effect at the time of the reading. Note that you can set the bufferVar.collectsourcevalues attribute only if the affected reading buffer is empty. See bufferVar.collectsourcevalues for more detailed information.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example 1

+

+ + + + + + +

sourcevalue = smua.nvbuffer1.sourcevalues[1]

+

 

+

Get the sourced value of the first reading stored in dedicated reading buffer 1.

+
+

Example 2

+

+ + + + + + +

printbuffer(1, 6, smua.nvbuffer1.sourcevalues)

+

Print the sourced value of the first 6 readings stored in source-measure unit (SMU) A, buffer 1.

+

Example output:

+

1.00000e-04, 1.00000e-04,

+

1.00000e-04, 1.00000e-04,

+

1.00000e-04, 1.00000e-04

+
+

Also see

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19920.htm b/WebHelpDocs/2601B-PULSE/19920.htm new file mode 100644 index 0000000..f177ab0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19920.htm @@ -0,0 +1,115 @@ + + + + + bufferVar.readings + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.readings

+

This attribute contains the readings stored in a specified reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

reading = bufferVar.readings[N]

+

+ + + + + + + + + + + + + + +

reading

+

The value of the reading in the specified reading buffer

+

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+

N

+

The reading number N; can be any value from 1 to the number of readings in the buffer; use the bufferVar.n command to determine the number of readings in the buffer

+
+

Details

+

The readings buffer recall attribute is like an array (a Lua table) of the readings stored in the reading buffer. This array holds the same data that is returned when the reading buffer is accessed directly; that is, rb[2] and rb.readings[2] access the same value.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example

+

+ + + + + + +

print(smua.nvbuffer1.readings[1])

+

Output the first reading saved in source-measure unit (SMU) channel A, dedicated reading buffer 1.

+

Output:

+

8.81658e-08

+
+

Also see

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19922.htm b/WebHelpDocs/2601B-PULSE/19922.htm new file mode 100644 index 0000000..b8e4396 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19922.htm @@ -0,0 +1,117 @@ + + + + + bufferVar.timestamps + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.timestamps

+

When enabled by the bufferVar.collecttimestamps attribute, this attribute contains the timestamp when each reading saved in the specified reading buffer occurred.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

timestamp = bufferVar.timestamps[N]

+

+ + + + + + + + + + + + + + +

timestamp

+

The complete timestamp (including date, time, and fractional seconds) of reading number N in the specified reading buffer when the reading was acquired

+

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+

N

+

The reading number (1 to bufferVar.n)

+
+

Details

+

The bufferVar.timestamps information from a reading buffer is only available if the bufferVar.collecttimestamps attribute is set to 1 (default setting). If it is set to 0, you cannot access any time information from a reading buffer.

+

If enabled, this buffer recall attribute is like an array (a Lua table) that contains timestamps, in seconds, of when each reading occurred. These are relative to the bufferVar.basetimestamp for the buffer.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+

Example

+

+ + + + + + +

timestamp = smua.nvbuffer1.timestamps[1]

+

 

+

Get the timestamp of the first reading stored in source-measure unit (SMU) A, buffer 1.

+
+

Also see

+

bufferVar.clear()

+

bufferVar.collecttimestamps

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.statuses

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19929.htm b/WebHelpDocs/2601B-PULSE/19929.htm new file mode 100644 index 0000000..e7fb10f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19929.htm @@ -0,0 +1,104 @@ + + + + + os.remove() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

os.remove()

+

This function deletes the file or directory with a given name.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

success, msg = os.remove("filename")

+

+ + + + + + + + + + + + + + +

success

+

A success indicator (true or nil)

+

msg

+

A message value (nil or an error message)

+

filename

+

A string representing the name of the file or directory to delete

+
+

Details

+

Directories must be empty before using the os.remove() function to delete them.

+

If this function fails, it returns nil (for success) and an error message string (for msg).

+

Example

+

+ + + + + + +

os.remove("testFile")

+

Delete the file named testFile.

+
+

Also see

+

os.rename()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19930.htm b/WebHelpDocs/2601B-PULSE/19930.htm new file mode 100644 index 0000000..476260f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19930.htm @@ -0,0 +1,110 @@ + + + + + os.rename() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

os.rename()

+

This function renames an existing file or directory.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

success, msg = os.rename("oldname", "newname")

+

+ + + + + + + + + + + + + + + + + + +

success

+

A success indicator (true or nil)

+

msg

+

A message value (nil or an error message)

+

oldname

+

String representing the name of the file or directory to rename

+

newname

+

String represent the new name of the file or directory

+
+

Details

+

If this function fails, it returns nil (for success) and an error message string (for msg).

+

Example

+

+ + + + + + +

os.rename("testFile", "exampleFile")

+

 

+

Changes the name of the existing file testFile to the name exampleFile.

+
+

Also see

+

os.remove()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/19931.htm b/WebHelpDocs/2601B-PULSE/19931.htm new file mode 100644 index 0000000..c1a7fe6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/19931.htm @@ -0,0 +1,100 @@ + + + + + script.factory.catalog() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

script.factory.catalog()

+

This function returns an iterator that can be used in a for loop to iterate over all the factory scripts.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

for name in script.factory.catalog() do body end

+

+ + + + + + + + + + +

name

+

String representing the name of the script

+

body

+

Code that implements the body of the for loop to process the names in the catalog

+
+

Details

+

Accessing this catalog of scripts allows you to process the factory scripts. The entries will be enumerated in no particular order.

+

Each time the body of the function executes, name takes on the name of one of the factory scripts. The for loop repeats until all scripts have been iterated.

+

Example

+

+ + + + + + +

for name in script.factory.catalog() do

+

print(name)

+

end

+

Retrieve the catalog listing for factory scripts.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2408.htm b/WebHelpDocs/2601B-PULSE/2408.htm new file mode 100644 index 0000000..6b90ce9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/2408.htm @@ -0,0 +1,47 @@ + + + + + Delete user scripts from the instrument + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Delete user scripts from the instrument

+

In most circumstances, you can delete a script using script.delete() (as described in Delete user scripts), and then turn the instrument off and back on again. However, if you cannot turn the instrument off, you can use the following steps to completely remove a script from the instrument.

+

When you completely remove a script, you delete all references to the script from the runtime environment, the script.user.scripts table, and nonvolatile memory.

+

To completely remove a script:

+
  1. Remove the script from the runtime environment. Set any variables that refer to the script to nil or assign the variables a different value. For example, to remove the script "beepTwoSec" from the runtime environment, send the following code:
    beepTwoSec = nil
  2. Remove the script from the script.user.scripts table. Set the name attribute to an empty string (""). This makes the script nameless, but does not make the script become the anonymous script. For example, to remove the script named "beepTwoSec", send the following code:
    script.user.scripts.beepTwoSec.name = ""
  3. Remove the script from nonvolatile memory. To delete the script from nonvolatile memory, send the command:
    script.delete("name")

    Where name is the name that the script was saved as. For example, to delete "beepTwoSec", you would send:
    script.delete("beepTwoSec")

    +
+ + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2430.htm b/WebHelpDocs/2601B-PULSE/2430.htm new file mode 100644 index 0000000..6e74b3c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/2430.htm @@ -0,0 +1,91 @@ + + + + + Base library functions + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Base library functions

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Base library functions

+

Function

+

Description

+

collectgarbage()

+

collectgarbage(limit)

+

Sets the garbage-collection threshold to the given limit (in kilobytes) and checks it against the byte counter. If the new threshold is smaller than the byte counter, Lua immediately runs the garbage collector. If there is no limit parameter, it defaults to zero (0), which forces a garbage-collection cycle. See Lua memory management for more information.

+

gcinfo()

+

Returns the number of kilobytes of dynamic memory that the Test Script Processor (TSP®) scripting engine is using and returns the present garbage collector threshold (also in kilobytes). See Lua memory management for more information.

+

tonumber(x)

+

tonumber(x, base)

+

Returns x converted to a number. If x is already a number, or a convertible string, the number is returned; otherwise, it returns nil.

+

An optional argument specifies the base to use when interpreting the numeral. The base may be any integer from 2 to 36, inclusive. In bases above 10, the letter A (in either upper or lower case) represents 10, B represents 11, and so forth, with Z representing 35. In base 10, the default, the number may have a decimal part, as well as an optional exponent. In other bases, only unsigned integers are accepted.

+

tostring(x)

+

Receives an argument of any type and converts it to a string in a reasonable format.

+

type(v)

+

Returns (as a string) the type of its only argument. The possible results of this function are "nil" (a string, not the value nil), "number", "string", "boolean", "table", "function", "thread", and "userdata".

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2450_toc.xml b/WebHelpDocs/2601B-PULSE/2450_toc.xml new file mode 100644 index 0000000..e69de29 diff --git a/WebHelpDocs/2601B-PULSE/2450commanddescription-details_lr.png b/WebHelpDocs/2601B-PULSE/2450commanddescription-details_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..407a7cb32178d2dd5b04a99a8abc5db54a8786d3 GIT binary patch literal 2141 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 f6F>&RX#71c*H~MZDiY`U!;G@LI_85EWBfR literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2450tspdescription-alsosee_lr.png b/WebHelpDocs/2601B-PULSE/2450tspdescription-alsosee_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..5a5e23cdca258046e0c03e97f01d703634425490 GIT binary patch literal 2006 zcmZ`)dpHve7oT*QTg?dHTo+l?M0$ydtYOGdyr^D7hGfkx!*ZWnL@v3_R#6sm86ns4 zpA`&w0){&v~BT?K@|PjWYlMj@&Xw8QTSa`bNciWjM&Z&43=NIm$_@IVEat(ixTf;<((c zgx6OV?0L(-?PJ-fmKKEio-eLeP0L+x=yV=qd+MgE*LMEJZIsSl& z>y>I2M*?kE-K$6G>l#2P>Zj76G!mHD0{Z`u@EFG1*w|=u(S$rq$Go`uynZoE5}5#& z+%--uDJf}bX<;z5n#1^QdkP3eEp&SP=>~2Ohr@|ccqN!4I`h{Xqb1ekh6er9u*meH zBGo@xEY^9-hxugRZRA&+WeF#No|)u|Yc94M(%IQGEm z_~78Qs%TZWdwOMUZEbnEhJ}BNvwfXCO| zpi-$Xb-p~aS?Eer&eS}jsik@O0w?8-w&&Cee4@v1Gib9d=Ez6|wl1qo8p_{d=qraN z>a1WyL#yNn#>K^blWLjpF}#`*Qm59YDik>BmUHZt#$swV%o5smO+iddEYtB*mIx9E z&7w_DPZ!6!HtJ_-ND2>+*AWy)uF)}iI9MB;vrcp>oe>tCpdZL=ye<<#o+uJ%sDvx= z2U?0mE6%3U=x52GFOmOtu_!DMs>0*<{1?!?=C)~jR0Q!{Zt{dOlpK7OJq!I+KQo!X z$JOc*8Z;o$pPE5YNR9uz7rw}}v57W>>C+wu4&H+sx)UrG?uhp4#7 zEU%i``dYgA7S>%rllu8}`)u=ZgjuwvTWws4XPq8h*J#CQ`}S`>leh7CQiRe{!+|%W zqKM{6N{)(Ua@nz$Rd74JpmJn-oO}%_=pyO!$E~C^LYKnscUK|`9012w21lD~DmYtL zlvS>__D$>9+uO&)#0+|!fAS&2N(CGg8imW~RuK^3CdeWN4o4L|YET`>>g=UN57}vC zSG$nbi%IJ0Cx@#%y<|UDSq@~1y|oudc6~j2vYD0=F*5R?GW=se+MNjhgY_Na%1N-) z<#{RZ6fsy%R|fW*nP>dkp&m7JQjaAdZAd?ybU%m^@WZmTbp&n~NP!klfed$bGrF4i-Oz}wabDlYy}SLN2O z{kWQA5P8b_iqt)CE2oWm&)7usz{$~|@*9`;?Oe%ym$N-yQ$9N49hv0~VRkO10*7lE zbJJ{JUb%GjvH*8Li!-Zbd@R@uVizKL`}I%1^AM~x907$<`oW5;mFT;pejY~=vhg@F z9P(<0Pf>h(JSNviAAv{;mHc&St%M6HZ0DgTMXF{t=CkPsAEfd!YUFdwq9n}liGDLH z1PO*I)hZ=1FyL)IlKbZZ;{Evb3&Ty#r@(6pcR1b1HXp-@Ck=aVi!t!h_f@TGhGQEW zGv^`QIuQ@^J}5W-P%FhVmB!xqb9Rc$%3eHD>j)FQgV>1Ua2SayQ}S`Q>Q*M1*kSpA zn7w;K&_S$*jcJp1dAqqr0Ncx0Ia1sVx z%5v(+4Asf;+m5#Coz~th7MFa|UGpHs%_(U9Uv2mC9Zr{CCW#AkMo%cR4q1XObaMQvXYv1C6oDQ9ELpSMed|F@idl1sV)M7Sy ztXg{2^XzQTnge^+FJn(Z1S*Bpp|IK(_+P}dpkhDmG#P{=|F0VUR~LVm8N!YZH!AUk gvo()Zx-aDd&?Uvb&O;d!`9B$8Zh}FTBVD5Z29j9K9smFU literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2450tspdescription-usage_lr.png b/WebHelpDocs/2601B-PULSE/2450tspdescription-usage_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..903feaf4e01199080aaa9902edf37c0e7e97b7dc GIT binary patch literal 11366 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 literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/24524.htm b/WebHelpDocs/2601B-PULSE/24524.htm new file mode 100644 index 0000000..6576a59 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/24524.htm @@ -0,0 +1,44 @@ + + + + + GPIB setup + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

GPIB setup

+

See the "GPIB setup" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2589.htm b/WebHelpDocs/2601B-PULSE/2589.htm new file mode 100644 index 0000000..01904c3 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/2589.htm @@ -0,0 +1,112 @@ + + + + + scriptVar.name + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

scriptVar.name

+

This attribute contains the name of a script in the runtime environment.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

No

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

scriptVar.name = "scriptName"

+

scriptName = scriptVar.name

+

+ + + + + + + + + + +

scriptVar

+

Name of the variable that references the script

+

scriptName

+

A string that represents the name of the script

+
+

Details

+

When setting the script name, this attribute renames the script that the variable scriptVar references.

+

This attribute must be either a valid Lua identifier or the empty string. Changing the name of a script changes the index that is used to access the script in the script.user.scripts table. Setting the attribute to an empty string removes the script from the table completely, and the script becomes an unnamed script.

+

As long as there are variables referencing an unnamed script, the script can be accessed through those variables. When all variables that reference an unnamed script are removed, the script is removed from the runtime environment.

+

If the new name is the same as a name that is already used for another script, the name of the other script is set to an empty string, and that script becomes unnamed.

+

VARIABLE - NOTE
Changing the name of a script does not change the name of any variables that reference that script. The variables still reference the script, but the names of the script and variables may not match.

+

Example

+

+ + + + + + + + +

test7 = script.new("display.clear() display.settext('Hello from my test')", "")

+

test7()

+

print(test7.name)

+

 

+

test7.name = "test7"

+

print(test7.name)

+

test7.save()

+

This example calls the script.new() function to create a script with no name, runs the script, names the script "test7", and then saves the script in nonvolatile memory.

+
+

Also see

+

Rename a script

+

script.new()

+

scriptVar.save()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/25959.htm b/WebHelpDocs/2601B-PULSE/25959.htm new file mode 100644 index 0000000..b85f9fe --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/25959.htm @@ -0,0 +1,146 @@ + + + + + os.time() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

os.time()

+

This function generates a time value in UTC time.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

utcTime = os.time()

+

utcTime = os.time(timespec)

+

+ + + + + + + + + + +

utcTime

+

Time value in UTC time

+

timespec

+

The date and time (year, month, day, hour, and minute)

+
+

Details

+

The timespec is a table using the fields listed in the table below.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

year

+

The year (1970 or later)

+

month

+

The month (1 to 12)

+

day

+

The day (1 to 31)

+

hour

+

The hour (00 to 23)

+

min

+

The minute (00 to 59)

+

sec

+

The second (00 to 59)

+
+

If the time (hour, minute, and second) options are not used, they default to noon for that day. When called without a parameter (the first form), the function returns the current time.

+

Set the time zone before calling the os.time() function.

+

Example

+

+ + + + + + +

systemTime = os.time({year = 2019,

+

month = 3,

+

day = 31,

+

hour = 14,

+

min = 25})

+

settime(systemTime)

+

Sets the date and time to Mar 31, 2019 at 2:25 pm.

+
+

Also see

+

settime()

+

settimezone()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2600A_toc.xml b/WebHelpDocs/2601B-PULSE/2600A_toc.xml new file mode 100644 index 0000000..e69de29 diff --git a/WebHelpDocs/2601B-PULSE/2600B_toc.xml b/WebHelpDocs/2601B-PULSE/2600B_toc.xml new file mode 100644 index 0000000..e69de29 diff --git a/WebHelpDocs/2601B-PULSE/2600_tsp_command_name_and_summary_table_lr.png b/WebHelpDocs/2601B-PULSE/2600_tsp_command_name_and_summary_table_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..a4939b7a407379744062145ae3cd61b4062f75a9 GIT binary patch literal 19416 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 KMNUMnLSTX%DtFre literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepilinmeasurev_lr.png b/WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepilinmeasurev_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..da2c17a0f870003ce065688d4544b554c166ef73 GIT binary patch literal 4054 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 literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepvlinmeasurei_lr.png b/WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepvlinmeasurei_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..8d15f38358ce3118835b45d2beeaf84f2d05634f GIT binary patch literal 4036 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 UDn2XrZ#jn*$l9#(hTD_>0m%;tg#Z8m literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepvlogmeasurei_lr.png b/WebHelpDocs/2601B-PULSE/2600s-901-01b_kisweeptsptestscript_sweepvlogmeasurei_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..edb36e3108eb777b98a4e98db501c565379fa9a0 GIT binary patch literal 3946 zcmbVPc{rO{`z9$}3~Cyo6s=B?+NO=FHPJS<)?TWiXzd}kwuGic+L^HxqqKJV5wsN* zOBE^7+6f&?5d@=_l6dWFM1JYa@4CMKzdz1%&UN1RdfxLq=YH9TDbRna;x={OM@08Tx^MfLQa7A=n=D+EYM4{FFKBihX#_5)*0h zi*s1}>hfyf6kF6<>{O-U-%4hdQ`iW*RO`J;F}W zpdC86v)aLjf%YKisCr}wmu*{1 z$y{pT8<#A`y}G>2&?+zeqHXRlbA5IpM9lnY4#w~0aFd!7DCX4|$jAE)1-a6nLfv;$s6kD%Kr$q81my>5Z;n4*b<37? z?a(i9{bXA?+AAF;=%yx-OLj#Tm!Rqpe)LAR>(n18}(%9dR@ z=2v)I9CQ6BEOyCzb1MM@+y1m-FtjX?ExD9brB~)&zivcwp|f)!-`^Hff}WUQ71e)E z58a6F)@j~T!n7zUYWC8_qLIBe8_Kw*@P#FR{#IFGw;}3$21AeH8l))`(9oNxN{O@Q zv|w+-&{vLO6;rvL%nyqI>O@b-vjEt`XO<`@)3e$V=syxpb~80RzVTnFgaA=C!!?&A zB{395WoIV$HN|1RO>zWvYoxk*3P7k-KJ73R(oT^qs-8;V-+qLkca4{~tjOS4+@P`X zBjB;quD#O=_2G2UmPVER--YZ*q$-^L!Le&r`%S*Acg>~cgRjO!%bAmOc5Y^*P-7iu z6J)tz4*UICn()4o^L9#FQS9kILHSPE~eY?r)sPVthJ(SjPo8bFn1jc_cWh0~(aYXia;o3`9NG4Bl1@@k}{$ znee)cR6S+9t08V0{^yf>736P#qXawN%Lh0Jxr%oqmJ|;VB;5$7nGP!qIzsKNe)|I$ zC63<7)KsjE6pm6zI1C&_vIiRB_zP3cxQZBvA5Iq#_iP!xFo=nlmQ?$WPSodKP@BBn$V(#(@Omh(I> zU}`n36tNJ_uzl9A*9y7Z1!8+Ci~mufS!IPowlp5JF_C3{HsEtvkT;O_FE!o`M-Ao+rLnOqjm%rIloaF?%mvadZrVy<=;rIEMoc!har~d)^=qFBae(ud! ze7AQ0!B`{GWBA~>u1IZfN~y%>435d7e=9CfJl6&EJ>~~vP|TJWEukr`WmMv|a`+Ga z8{)rl{#pfwQ(sdRDy8{}_$M3xgUNLpW(uYZL&Y(>UVjwu>So?`Jojx;x|oUBk-bj* zQGoeoqFU|t*Jmv4?)ul{F9Jr_0t9$E*Xjr^VWytCkP#U=lTWtSPGmC3#-`ou7`0?j z_DADMqG~aZ>)$eDa}2vSSIfCXLF15~5f5+KPn%XWo^R;%9&8y9)iG8;Qxbt! zbz{87nd6cBGF%Cm3Z?Ub?=MQK=ENn@*ce`v)2oT3%tUv+1#fNokP9dmo9n}R#8}J4 z?%q>V9W_WUFF|J(l7SBTBlyb)hn^V7ZtlnbX^nEgEHjB8R?r-G8`Sc_xsV+`&3iUXJnPBR_-V4L4qQbBHkQr}za zKkL+d5F;Zi%6I}%r-fF(cyCGWECQ1y8@5hn#4;~B7QE9EY4dagKapj(`9y26?i+wd zQ|G<4!?qQrLpw}7P8jG2OZk{4=*dl~fo4v>Ok7WK>(sMezJ|EYA#T8Hg{+GI-`Di? zfcS;ax&l$+`|qg=^ns+zT(A%Nv}(S}_h4k!BA5ysL|w0Pkr%E}?bq7SFv>!=GlQl% zuIz!+feO^{f~Lc(OZh}F4w>06g@NOSOYdp+ceKu{;6<@Lb%_#Fj8ZqJ$?hRhqN~~@ z?CZL3Y4!)nP?OaL(}qh^7fT=Lm=c1_1p{7IN`>;oHl2X(X(@G4JCgcZ=RnQF18M_%!}1L=3j$c*~l9o%8hI{vDs zulhY7D=1Q^lfsC1r%{Dbwjo^q@j{sKj90ZDrS%2SZI<}}7xFfioY!_(8_t?PsYGY1 zI2$T5@wdrT`r;-Xn^DH{Va2OKV)%Vz{q_g&DZv;tv-$Srtd)cPOHok8=URIprgVy^ zp%?KqsB47T)WVUo6OPk_SBC=PL2E$jyO+zLF&d1r1biFmr7;f|X%9sY6y(;P^Bra) z8)?AY7{fhD0S-+Jcglb;GAA^Y_jvE)SJfT{)qPB0kTEj^~XBhT0``SOa?V# z+ZqLR^uL=x*bAbyfxdER-giiQ61CltP_%!!`&-QJ?_~Z*x7&;KI3z7oJPBK$t1_I> zC=cSG@!7ONWrsQrZt5z|gDekshF1-+oBiy&%C<+j3+Z``GdEk7%X4m#^QsCiJlQ>^ zInHec_1qCO_10Drs@RVZa(N4%pQ{I4HLB(SpVjurJ5IyNHS1nJe5R7wX{ARAi;Z)` z+8zZx&x`~O`KUaq{Ql*l$yhpRaCMopb3{OXXl?2V}l4%l%|is#1fQ!XZR+>6(wuH|;%ANk-X=mkLmVJ_%L8#WH_g40Y!; z?~Im*Pj*ivn{}F=Ij1d`(mx=@>FXX{nO^>NEU=jFP_-Q%D zVt6*n&xr(C_Ux`NLTorL*-6wZmp#m4x0+ zQ`!;1uGc*XFTNT+3y@EhH`7``%YL)tIMR|U0x#pu`U;oYc->-{hmSrmUq3MGLIm{9 zkq7>c*!rMyBaL}hu6LnzbIw%mW8J-+T*LH0(LXFWPI$szSvi5ZJu#PdkQa=!bI!Nh`Zu}Zxe{Z# z!CFQ1YKa@GIEN^={oFE#L8c`y4A;FpkqYW6L^xD8i9GA#tPO^#j*hE$-ABrdy9D#* z8Ixx#8P6!LzzCk7Zrj{K^d6C~POa$dr&L0A;X(4vA@OL_Og{9; zei0q%gv=E#9$H0w4kBmCzQmc^^Z~CQT5O$ja3So@gnb(ciQ&x8PA{aSjFD*fA_AL8BW)og7B-q6V`4VQ8hK0RuNYX7Xa3sNcoZduD(oIfe z(6S8WV(-^ER@QkfnpZ5-;^6u9i(8jkzcNiotA&x6|V&H2(Yc-B| zlH77ZJ7^XC`N+g13ovcoUoMbTJ-8r$2S|OPuf&BjG*E0O01JRsuHPL+dJd_w9u9GM+DLJ5d1_Tu26wGf@-K%St7wig5 zhwpd^S2R4xe+;_Uw>06&xu_(!vYh(lGh%zdCbs={7Q=$Wd&cba-BwwJ&1t1;X z>m0p`xO&H1*hTK<&nZsi7JGZt%(;Jb9$y9iqtwh;(km}oEBy^-akQpXK<&6hgynFz mp6VkS{Gw)TtU)^ue95)Fr5|h(&;NNAFgLbBy}Nq%$^QYttk--1 literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2601B-PULSE_TSP_command_reference.htm b/WebHelpDocs/2601B-PULSE/2601B-PULSE_TSP_command_reference.htm new file mode 100644 index 0000000..5eaea7e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/2601B-PULSE_TSP_command_reference.htm @@ -0,0 +1,42 @@ + + + + + TSP command reference + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP command reference

+ + + + +
+

In this section:

TSP command programming notes

Using the TSP command reference

TSP commands

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2601B-PULSE_command_reference.htm b/WebHelpDocs/2601B-PULSE/2601B-PULSE_command_reference.htm new file mode 100644 index 0000000..b1a0f0e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/2601B-PULSE_command_reference.htm @@ -0,0 +1,28 @@ + + + + + 2601B-PULSE command reference + + + + +

2601B-PULSE command reference

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2601B-PULSE_introduction_to_TSP_operation.htm b/WebHelpDocs/2601B-PULSE/2601B-PULSE_introduction_to_TSP_operation.htm new file mode 100644 index 0000000..62ce579 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/2601B-PULSE_introduction_to_TSP_operation.htm @@ -0,0 +1,42 @@ + + + + + Remote commands + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Remote commands

+ + + + +
+

In this section:

Introduction to TSP operation

About TSP commands

Factory scripts

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/2601b-pulse_display_modes_lr.png b/WebHelpDocs/2601B-PULSE/2601b-pulse_display_modes_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..7e01be5ee46210a8ab1fa3502c85dd6239e2b081 GIT binary patch literal 27124 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 literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2601b-pulse_pulser_display_modes_lr.png b/WebHelpDocs/2601B-PULSE/2601b-pulse_pulser_display_modes_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..42902300534f4db045089ac6ec59216cda3d1468 GIT binary patch literal 26980 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 G1O6Aje(-Vt literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/2651A_toc.xml b/WebHelpDocs/2601B-PULSE/2651A_toc.xml new file mode 100644 index 0000000..e69de29 diff --git a/WebHelpDocs/2601B-PULSE/26898.htm b/WebHelpDocs/2601B-PULSE/26898.htm new file mode 100644 index 0000000..ff6176f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/26898.htm @@ -0,0 +1,227 @@ + + + + + digio.trigger[N].stimulus + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

digio.trigger[N].stimulus

+

This attribute selects the event that causes a trigger to be asserted on the digital output line.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Digital I/O trigger N reset
Recall setup

+

Not saved

+

0

+
+

Usage

+

triggerStimulus = digio.trigger[N].stimulus

+

digio.trigger[N].stimulus = triggerStimulus

+

+ + + + + + + + + + +

triggerStimulus

+

The event identifier for the triggering event

+

N

+

Digital I/O trigger line (1 to 14)

+
+

Details

+

Set this attribute to zero (0) to disable the automatic trigger output.

+

Do not use the stimulus attribute for generating output triggers under script control. Use digio.trigger[N].assert() instead.

+

The trigger stimulus for a digital I/O line may be set to one of the existing trigger event IDs, described in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Trigger event IDs*

+

Event ID

+

Event description

+

smua.trigger.SWEEPING_EVENT_ID

+

Occurs when the source-measure unit (SMU) transitions from the idle state to the arm layer of the trigger model

+

smua.trigger.ARMED_EVENT_ID

+

Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a source action

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a measurement action

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a pulse

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

Occurs when the SMU completes a sweep

+

smua.trigger.IDLE_EVENT_ID

+

Occurs when the SMU returns to the idle state

+

digio.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a digital I/O line

+

tsplink.trigger[N].EVENT_ID

+

Occurs when an edge is detected on a TSP-Link line

+

lan.trigger[N].EVENT_ID

+

Occurs when the appropriate LXI trigger packet is received on LAN trigger object N

+

display.trigger.EVENT_ID

+

Occurs when the TRIG key on the front panel is pressed

+

trigger.EVENT_ID

+

Occurs when a *TRG command is received on the remote interface

+

GPIB only: Occurs when a GET bus command is received

+

USB only: Occurs when a USBTMC TRIGGER message is received

+

VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation

+

trigger.blender[N].EVENT_ID

+

Occurs after a collection of events is detected

+

trigger.timer[N].EVENT_ID

+

Occurs when a delay expires

+

trigger.generator[N].EVENT_ID

+

Occurs when the trigger.generator[N].assert() function is executed

+

* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).

+
+

Example 1

+

+ + + + + + + + +

digio.trigger[3].stimulus = 0

+

Clear the trigger stimulus of digital I/O line 3.

+
+

Example 2

+

+ + + + + + + + +

digio.trigger[3].stimulus = smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

Set the trigger stimulus of digital I/O line 3 to be the source complete event.

+
+

Also see

+

digio.trigger[N].assert()

+

digio.trigger[N].clear()

+

digio.trigger[N].reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/26xxas-901-01e_fourquadrantsofoperation.png b/WebHelpDocs/2601B-PULSE/26xxas-901-01e_fourquadrantsofoperation.png new file mode 100644 index 0000000000000000000000000000000000000000..cc71e5dcff3aca7706d82c7d1a52dadbe8df2f2f GIT binary patch literal 35478 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

qoY*GWhYa_2OOv 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 z�)?U{o^NR(ZrMIb5xJ_Wf4HLI2y#TlJhFTc`L6_iHhj#UgZN5bBaY1lmquw?--n zKkM4Xgl#;@)e3pufI*g7$G64P(DZ=+?!?8pWSb+I@Y5Bo#cg%G=z|EoDZ2r0tbj;n zQe$$5>TaWzdpXNG5?etYUm%d#tFmHsv9V2;1t*}M1_SAFI&FD<&$wSdE0I2wJgH~; z$f>o|ufv(T-%fT(vkEp@XnZBx6Bin2Azc0@`Tqm4_UT;+FM*&+2E>=_eF>qfEYH1R7pwpJ$vJH=e^@H(86k4m1I+Gq9kjC^

~OEr0e1C5EJBq0Bof@#w2 zV$^SW{t-{+fQY_sd&Z?f9Cq~)#H9!LO@E#Y4k~zI{k{1Nox*g10Z$c&Jo}(Y!m>S4#()5U zPCzj{RT}c?p9to^f8|xjjRAS70&jiA1cA7o$+wzlWnChxL*o9?WWdD+|D$m5-vq={ z4)BBJysp$tLX#W+v1k9$ + + + + node[N].execute() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

node[N].execute()

+

This function starts test scripts from a remote node.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes (see Details)

+

 

+

 

+

 

+
+

Usage

+

node[N].execute("scriptCode")

+

+ + + + + + + + + + +

N

+

The node number of this instrument

+

scriptCode

+

A string containing the source code

+
+

Details

+

Only the remote master node can use the execute command to run a script on this node. This function does not run test scripts on the master node; only on this node when initiated by the master node.

+

This function may only be called when the group number of the node is different than the node of the master.

+

This function does not wait for the script to finish execution.

+

This command should only be used from a remote master when controlling this instrument over a TSP-Link®.

+

Example 1

+

+ + + + + + +

node[2].execute(sourcecode)

+

Runs script code on node 2. The code is in a string variable called sourcecode.

+
+

Example 2

+

+ + + + + + +

node[3].execute("x = 5")

+

Runs script code in string constant ("x = 5") to set x

+

equal to 5 on node 3.

+
+

Example 3

+

+ + + + + + +

node[32].execute(TestDut.source)

+

Runs the test script stored in the variable TestDut

+

(previously stored on the master node) on node 32.

+
+

Also see

+

TSP advanced features

+

tsplink.group

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/29218.htm b/WebHelpDocs/2601B-PULSE/29218.htm new file mode 100644 index 0000000..89d243e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/29218.htm @@ -0,0 +1,91 @@ + + + + + trigger.generator[N].assert() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.generator[N].assert()

+

This function generates a trigger event.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

trigger.generator[N].assert()

+

+ + + + + + +

N

+

The generator number (1 or 2)

+
+

Details

+

Use this function to directly trigger events from the command interface or a script. For example, you can trigger a sweep while the instrument is under script control.

+

Example

+

+ + + + + + +

trigger.generator[2].assert()

+

Generates a trigger event on generator 2.

+
+

Also see

+

trigger.generator[N].EVENT_ID

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/29219.htm b/WebHelpDocs/2601B-PULSE/29219.htm new file mode 100644 index 0000000..a049c49 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/29219.htm @@ -0,0 +1,100 @@ + + + + + trigger.generator[N].EVENT_ID + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

trigger.generator[N].EVENT_ID

+

This constant identifies the trigger event generated by the trigger event generator.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Constant

+

Yes

+

 

+

 

+

 

+
+

Usage

+

eventID = trigger.generator[N].EVENT_ID

+

+ + + + + + + + + + +

eventID

+

The trigger event number

+

N

+

The generator number (1 or 2)

+
+

Details

+

This constant is an identification number that identifies events generated by this generator.

+

To have another trigger object respond to trigger events generated by this generator, set the other object's stimulus attribute to the value of this constant.

+

Example

+

+ + + + + + + + +

digio.trigger[5].stimulus = trigger.generator[2].EVENT_ID

+

Uses a trigger event on generator 2 to be the stimulus for digital I/O trigger line 5.

+
+

Also see

+

trigger.generator[N].assert()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/29234.htm b/WebHelpDocs/2601B-PULSE/29234.htm new file mode 100644 index 0000000..52fe951 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/29234.htm @@ -0,0 +1,538 @@ + + + + + status.operation.instrument.trigger_blender.trigger_overrun.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.trigger_blender.trigger_overrun.*

+

This attribute contains the operation status trigger blender overrun register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

126 (All bits set)

+
+

Usage

+

operationRegister =

+

status.operation.instrument.trigger_blender.trigger_overrun.condition

+

operationRegister =

+

status.operation.instrument.trigger_blender.trigger_overrun.enable

+

operationRegister =

+

status.operation.instrument.trigger_blender.trigger_overrun.event

+

operationRegister =

+

status.operation.instrument.trigger_blender.trigger_overrun.ntr

+

operationRegister =

+

status.operation.instrument.trigger_blender.trigger_overrun.ptr

+

status.operation.instrument.trigger_blender.trigger_overrun.enable =

+

operationRegister

+

status.operation.instrument.trigger_blender.trigger_overrun.ntr =

+

operationRegister

+

status.operation.instrument.trigger_blender.trigger_overrun.ptr =

+

operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status trigger blender overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status trigger blender overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 18 is read as the value of the condition register, the binary equivalent is 0000 0000 0001 0010. This value indicates that bit B1 and bit B4 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

A set bit value indicates that the specified trigger blender generated an action overrun.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

Decimal value

+

B0

+

Not used

+

Not applicable

+

B1

+

status.operation.instrument.trigger_blender.trigger_overrun.BLND1

+

2

+

B2

+

status.operation.instrument.trigger_blender.trigger_overrun.BLND2

+

4

+

B3

+

status.operation.instrument.trigger_blender.trigger_overrun.BLND3

+

8

+

B4

+

status.operation.instrument.trigger_blender.trigger_overrun.BLND4

+

16

+

B5

+

status.operation.instrument.trigger_blender.trigger_overrun.BLND5

+

32

+

B6

+

status.operation.instrument.trigger_blender.trigger_overrun.BLND6

+

64

+

B7 to B15

+

Not used

+

Not applicable

+
+

As an example, to set bit B1 of the operation status trigger blender overrun enable register, set status.operation.instrument.trigger_blender.trigger_overrun.enable = status.operation.instrument.trigger_blender.trigger_overrun.BLND1.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set operationRegister to 18 (which is the sum of 2 + 16).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example

+

+ + + + + + + + +

status.operation.instrument.trigger_blender.trigger_overrun.enable

+

= status.operation.instrument.trigger_blender.trigger_overrun.BLND1

+

Uses the constant to set the bit for blender 1 of the operation status trigger blender overrun enable register.

+
+

Example

+

+ + + + + + + + +

status.operation.instrument.trigger_blender.trigger_overrun.enable = 18

+

Uses the decimal value to set the bits for blenders 1 and 4 of the operation status trigger blender overrun enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.instrument.trigger_blender.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/29255.htm b/WebHelpDocs/2601B-PULSE/29255.htm new file mode 100644 index 0000000..81303e7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/29255.htm @@ -0,0 +1,326 @@ + + + + + status.condition + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.condition

+

This attribute stores the status byte condition register.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+
+

Usage

+

statusByte = status.condition

+

+ + + + + + +

statusByte

+

The status byte; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

This attribute is used to read the status byte, which is returned as a numeric value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

The returned value can indicate one or more status events occurred. When an enabled status event occurs, a summary bit is set in this register to indicate the event occurrence.

+

The individual bits of this register have the following meanings:

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.MEASUREMENT_SUMMARY_BIT

+

status.MSB

+

Set summary bit indicates that an enabled measurement event has occurred.

+

Bit B0 decimal value: 1

+

B1

+

status.SYSTEM_SUMMARY_BIT

+

status.SSB

+

Set summary bit indicates that an enabled system event has occurred.

+

Bit B1 decimal value: 2

+

B2

+

status.ERROR_AVAILABLE

+

status.EAV

+

Set summary bit indicates that an error or status message is present in the Error Queue.

+

Bit B2 decimal value: 4

+

B3

+

status.QUESTIONABLE_SUMMARY_BIT

+

status.QSB

+

Set summary bit indicates that an enabled questionable event has occurred.

+

Bit B3 decimal value: 8

+

B4

+

status.MESSAGE_AVAILABLE

+

status.MAV

+

Set summary bit indicates that a response message is present in the Output Queue.

+

Bit B4 decimal value: 16

+

B5

+

status.EVENT_SUMMARY_BIT

+

status.ESB

+

Set summary bit indicates that an enabled standard event has occurred.

+

Bit B5 decimal value: 32

+

B6

+

status.MASTER_SUMMARY_STATUS

+

status.MSS

+

Request Service (RQS)/Master Summary Status (MSS). Depending on how it is used, bit B6 of the status byte register is either the Request for Service (RQS) bit or the Master Summary Status (MSS) bit:

+
  • When using the GPIB, USB, or VXI-11 serial poll sequence of the 2601B-PULSE to obtain the status byte (serial poll byte), B6 is the RQS bit. The set bit indicates that the Request Service (RQS) bit of the status byte (serial poll byte) is set and a service request (SRQ) has occurred.
  • When using the status.condition register command or the *STB? common command to read the status byte, B6 is the MSS bit. Set bit indicates that an enabled summary bit of the status byte register is set.

    Bit B6 decimal value: 64

    +

B7

+

status.OPERATION_SUMMARY_BIT

+

status.OSB

+

Set summary bit indicates that an enabled operation event has occurred.

+

Bit B7 decimal value: 128

+
+

In addition to the above constants, when more than one bit of the register is set, statusByte equals the sum of their decimal weights. For example, if 129 is returned, bits B0 and B7 are set (1 + 128).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

Example

+

+ + + + + + + + +

statusByte = status.condition

+

print(statusByte)

+

Returns statusByte.

+

Sample output:

+

1.29000e+02

+

Converting this output (129) to its binary equivalent yields 1000 0001

+

Therefore, this output indicates that the set bits of the status byte condition register are presently B0 (MSS) and B7 (OSB).

+
+

Also see

+

Status byte and service request (SRQ)

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/29272.htm b/WebHelpDocs/2601B-PULSE/29272.htm new file mode 100644 index 0000000..ea439e2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/29272.htm @@ -0,0 +1,44 @@ + + + + + Setting a value + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Setting a value

+

See the "Setting a value" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/3240.htm b/WebHelpDocs/2601B-PULSE/3240.htm new file mode 100644 index 0000000..7ffe8a7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/3240.htm @@ -0,0 +1,45 @@ + + + + + Using groups to manage nodes on TSP-Link network + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Using groups to manage nodes on TSP-Link network

+

The primary purpose of groups is to allow each group to run a different test script simultaneously.

+

A group can consist of one or more nodes. You must assign group numbers to each node using remote commands. If you do not assign a node to a group, it defaults to group 0, which will always be grouped with the master node (regardless of the group to which the master node is assigned).

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/3247.htm b/WebHelpDocs/2601B-PULSE/3247.htm new file mode 100644 index 0000000..83004c7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/3247.htm @@ -0,0 +1,48 @@ + + + + + Using the data queue for real-time communication + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Using the data queue for real-time communication

+

Nodes that are running test scripts at the same time can store data in the data queue for real-time communication. Each instrument has an internal data queue that uses the first-in, first-out (FIFO) structure to store data. You can use the data queue to post numeric values, strings, and tables.

+

Use the data queue commands to:

+
  • Share data between test scripts running in parallel
  • Access data from a remote group or a local node on a TSP-Link® network at any time

You cannot access the reading buffers or global variables from any node in a remote group while a node in that group is performing an overlapped operation. However, you can use the data queue to retrieve data from any node in a group that is performing an overlapped operation. In addition, the master node and the group leaders can use the data queue to coordinate activities.

+

Tables in the data queue consume one entry. When a node stores a table in the data queue, a copy of the data in the table is made. When the data is retrieved from the data queue, a new table is created on the node that is retrieving the data. The new table contains a separate copy of the data in the original table, with no references to the original table or any subtables.

+

You can access data from the data queue even if a remote group or a node has overlapped operations in process. See the dataqueue commands in the TSP command reference for more information.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/3249.htm b/WebHelpDocs/2601B-PULSE/3249.htm new file mode 100644 index 0000000..db05b37 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/3249.htm @@ -0,0 +1,65 @@ + + + + + Removing stale values from the reading buffer cache + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Removing stale values from the reading buffer cache

+

The node that acquires the data also stores the data for the reading buffer. To optimize data access, all nodes can cache data from the node that stores the reading buffer data.

+

When you run Lua code remotely, it can cause reading buffer data that is held in the cache to become stale. If the values in the reading buffer change while the Lua code runs remotely, another node can hold stale values. Use the clearcache() command to clear the cache. For additional detail on the reading buffer cache commands, see bufferVar.cachemode and bufferVar.clearcache().

+

The following example code demonstrates how stale values occur and how to use the clearcache() command to clear the cache on node 2, which is part of group 7.

+

-- Create a reading buffer on a node in a remote group.

+

node[2].tsplink.group = 7

+

node[2].execute("rbremote = smua.makebuffer(20)" ..

+

"smua.measure.count = 20 " ..

+

"smua.measure.v(rbremote)")

+

-- Create a variable on the local node to

+

-- access the reading buffer.

+

rblocal = node[2].getglobal("rbremote")

+

-- Access data from the reading buffer.

+

print(rblocal[1])

+

-- Run code on the remote node that updates the reading buffer.

+

node[2].execute("smua.measure.v(rbremote)")

+

-- Use the clearcache command if the reading buffer contains cached data.

+

rblocal.clearcache()

+

-- If you do not use the clearcache command, the data buffer

+

-- values will never update. Every time the print command is

+

-- issued after the first print command, the same data buffer

+

-- values will print.

+

print(rblocal[1])

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/368.htm b/WebHelpDocs/2601B-PULSE/368.htm new file mode 100644 index 0000000..754ab3c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/368.htm @@ -0,0 +1,58 @@ + + + + + Queries + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Queries

+

Test Script Processor (TSP®) enabled instruments do not have inherent query commands. Like any other scripting environment, the print() and printnumber() commands generate output in the form of response messages. Each print() command creates one response message.

+

Example

+

+ + + + + + +

x = 10

+

print(x)

+

Example of an output response message:

+

10

+

Note that your output may be different if you set your ASCII precision setting to a different value.

+
+

+ + + + +
+

See also

Introduction to TSP operation

Controlling the instrument by sending individual command messages

Information on scripting and programming

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/3700S_toc.xml b/WebHelpDocs/2601B-PULSE/3700S_toc.xml new file mode 100644 index 0000000..57747e5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/3700S_toc.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/4200a_lc_next_button.png b/WebHelpDocs/2601B-PULSE/4200a_lc_next_button.png new file mode 100644 index 0000000000000000000000000000000000000000..5ed6226518edd14d91bdad650d64997e44eb14dc GIT binary patch literal 730 zcmV<00ww*4P){vZ4Ls1z0h!F7;K}gg<6Je=M5C+O*At44oi5NOqq?<`1G1w5MHev8HwMjc* zX)tIIlUhgJ@qOEC2j6WZf<*jUVG0w=lj0*a^mrL7ZI(CR!0h{ zu#_W+iUdwC>jEcNiVhQ0SCo)*%uabw5=goTM-?k3xCj&Vwl-0&qT**zMEwwX>AG-l zTN6t*_V7rH8~dN;7N!TdpIP=PqN>YF$ktFpHmVUmzoo#*WnvEFzlojIDV=zK+G6dW zSkE!oK}CfH%6i}7`Q?>K8trQ#m-onY4dxv~9c)#($K?&O3bAiQwAjNFP0ns`x?Y3-VYJ)viP>xd%yFf_NgISOa2=2|=nb zBdw09z&75B8A=amqkL$P{$poscE zqKXUi6%*e81u%m7fk@F^$SewG5A69|!-1$W@qI$HGDS;D9KH)M01Oi!_;L}tl>h($ M07*qoM6N<$f@DoQL;wH) literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/4200a_lc_previous_button.png b/WebHelpDocs/2601B-PULSE/4200a_lc_previous_button.png new file mode 100644 index 0000000000000000000000000000000000000000..8f57ca35ebef99bdfe8a9878b381c298880a449c GIT binary patch literal 1031 zcmV+i1o-=jP){v}mR8bVZ)-=-igFn$k8t8!F#@R(mEv(#B3j?8r83e&Bq6l{d1raTz78ykg z7a7#JFa&2&EfjT8%t#dUW|1;71LX`j_yd|re@yo~@1DoYd84mzV2pQ$=bLxuy?f93 z&Ue0ZeMOl}rd0^hFONFmST5@=l0YR!C#UL0BhwBX7Ur!k6Wv|MgbPdpNYPl*LB+zN zF(KLxHHsY$6!xs3fjWEgARUEZuFY=n)$S32jw4y)VJ$9Dva4&~^5$Hp0x9_NZQ%n| zvb$I`HSEtC#~8AGxo1$!Ev)3lxvTd>1;cKa-5aB^lyrR90PjZN1c8OD-+MZiCm~I4 zKcLKpazp6>C~s9cjrCkPP1ggmOpZ4}X>$T_ zjd8hMA@E;3yh!7xEnr&ajpZ6hKE%%m5gkLEuP+)iYLlOUadq9F~4!ExXOgHc)0!=U|v6>&w#E)ylwN z?X7;=v;kl<8$%Ns1=`e5BT78Qs+(E|%yXG_i<=0~XGil;>WE|T?gjeJ-8(O0{;zu)$(58>NdRqI++-nA-+Ol@>r^aWx0Z%!Jcm z6v`@>sG@8;<=GEVVGeXWJlEp)8B%}* zZMGHJc~jcxBtPWrOp*Xu zTK;P2Ok@2%y7&3Wdt+P>dunJLz%p~NMyU!MC4HxV#8?k!eHH!hlTd`#hX06BkKwbZ zEcXcaE|>B*DSDrcQ4(_*n26Ub8QxDBQX$)x}Q002ovPDHLkV1jfD B<4^zq literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/46200.htm b/WebHelpDocs/2601B-PULSE/46200.htm new file mode 100644 index 0000000..978c2a0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/46200.htm @@ -0,0 +1,42 @@ + + + + + Additional 2601B-PULSE information + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Additional 2601B-PULSE information

+ + + + +
+

In this section:

Additional information

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/492.htm b/WebHelpDocs/2601B-PULSE/492.htm new file mode 100644 index 0000000..5a80e19 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/492.htm @@ -0,0 +1,98 @@ + + + + + Attributes + + + + + + + + + +
+

Previous Icon

+

Next Icon

+
Attributes
+

Attribute-based commands are commands that set the characteristics of an instrument feature or operation. For example, a characteristic of TSP-enabled instruments is the model number (localnode.model).

+

Attributes can be read-only, read-write, or write-only. They can be used as a parameter of a function or assigned to another variable.

+ +

To set the characteristics, attribute-based commands define a value. For many attributes, the value is in the form of a number or a predefined constant.

+

Example 1: Set an attribute using a number

+

+ + + + + + + + +

beeper.enable = 0

+

This attribute controls the beeps that occur when front-panel controls are selected. Setting this attribute to 0 turns off the beeper.

+
+

Example 2: Set an attribute using a constant

+

+ + + + + + + + +

format.data = format.REAL64

+

Using the constant REAL64 sets the print format to double precision floating-point format.

+
+

+ +

To read an attribute, you can use the attribute as the parameter of a function, or assign it to another variable.

+

Example 3: Read an attribute using a function

+

+ + + + + + + + +

print(format.data)

+

Reads the data format by passing the attribute to the print function. If the data format is set to 3, the output is:

+

3.00000e+00

+

This shows that the data format is set to double precision floating point.

+
+

Example 4: Read an attribute using a variable

+

+ + + + + + + + +

fd = format.data

+

This reads the data format by assigning the attribute to a variable named fd.

+
+

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/6500_toc.xml b/WebHelpDocs/2601B-PULSE/6500_toc.xml new file mode 100644 index 0000000..e69de29 diff --git a/WebHelpDocs/2601B-PULSE/6510_toc.xml b/WebHelpDocs/2601B-PULSE/6510_toc.xml new file mode 100644 index 0000000..e69de29 diff --git a/WebHelpDocs/2601B-PULSE/66559.htm b/WebHelpDocs/2601B-PULSE/66559.htm new file mode 100644 index 0000000..6f2d771 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/66559.htm @@ -0,0 +1,99 @@ + + + + + lan.config.dns.hostname + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

lan.config.dns.hostname

+

This attribute defines the dynamic DNS host name.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

Instrument specific (see Details)

+
+

Usage

+

hostName = lan.config.dns.hostname

+

lan.config.dns.hostname = "hostName"

+

+ + + + + + +

hostName

+

The host name to use for dynamic DNS registration; the host name must:

+
  • be a string of 63 characters or less
  • start with a letter
  • end with a letter or digit
  • contain only letters, digits, and hyphens
+

Details

+

This attribute holds the host name to request during dynamic DNS registration. Dynamic DNS registration works with DHCP to register the host name specified in this attribute with the DNS server.

+

The factory default value for hostName is "k-<model number>-<serial number>", where <model number> and <serial number> are replaced with the actual model number and serial number of the instrument (for example, "k-2601B-PULSE-1234567"). Note that hyphens separate the characters of hostName.

+

The length of the fully qualified host name (combined length of the domain and host name with separator characters) must be less than or equal to 255 characters. Although up to 63 characters can be entered here, care must be taken to be sure the combined length is no more than 255 characters.

+

Setting this attribute to an empty string (in other words, setting this attribute to a string of length zero, or one consisting entirely of whitespace characters) will revert the host name to the factory default value.

+

Example

+

+ + + + + + + + +

print(lan.config.dns.hostname)

+

Outputs the present dynamic DNS host name.

+
+

Also see

+

lan.config.dns.domain

+

lan.config.dns.dynamic

+

lan.restoredefaults()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/66560.htm b/WebHelpDocs/2601B-PULSE/66560.htm new file mode 100644 index 0000000..57df49c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/66560.htm @@ -0,0 +1,90 @@ + + + + + io.input() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

io.input()

+

This function assigns a previously opened file, or opens a new file, as the default input file.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes (see Details)

+

 

+

 

+

 

+
+

Usage

+

fileVar = io.input()

+

fileVar = io.input("newfile")

+

+ + + + + + + + + + +

fileVar

+

The descriptor of the input file or an error message (if the function fails)

+

newfile

+

A string representing the path of a file to open as the default input file, or the file descriptor of an open file to use as the default input file

+
+

Details

+

The newfile path may be absolute or relative to the current working directory.

+

When using this function from a remote TSP-Link® node, this command does not accept a file descriptor and does not return a value.

+

If the function fails, an error message is returned.

+

Also see

+

io.open()

+

io.output()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/66566.htm b/WebHelpDocs/2601B-PULSE/66566.htm new file mode 100644 index 0000000..b2c80ca --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/66566.htm @@ -0,0 +1,105 @@ + + + + + setup.recall() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

setup.recall()

+

This function recalls settings from a saved setup.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

setup.recall(id)

+

+ + + + + + +

id

+

An integer or string that specifies the location of the setup to recall:

+
  • Factory default setup: 0
  • User-saved setup in nonvolatile memory: 1 to 5
  • User-saved setup on a USB flash drive: "/path/filename"
+

Details

+

When the id parameter is an integer (n), it is interpreted as the setup number to restore from the instrument's nonvolatile memory. When = 0, the instrument recalls the factory default setup; when = 1 to 5, the instrument recalls a user-saved setup.

+

When the id parameter is a string, it is interpreted as the path and file name of the setup to restore from a file on a USB flash drive. The path may be absolute or relative to the current working directory.

+

Before a setup is recalled, an instrument reset is performed.

+

Example 1

+

+ + + + + + +

setup.recall(1)

+

Recall the user-saved setup at location 1.

+
+

Example 2

+

+ + + + + + +

setup.recall("/usb1/KEITHLEY_30730.set")

+

Recall a user-saved setup stored in a file named KEITHLEY_30730 on a USB flash drive.

+
+

Also see

+

Saved setups

+

setup.save()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/72522.htm b/WebHelpDocs/2601B-PULSE/72522.htm new file mode 100644 index 0000000..09c8b0e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/72522.htm @@ -0,0 +1,49 @@ + + + + + Userstrings + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Userstrings

+

Use the functions in this group to store and retrieve user-defined strings in nonvolatile memory. These strings are stored as key-value pairs. The key is a unique identifier such as a part number or identification string.

+

You can use the userstring functions to store custom, instrument-specific information in the instrument, such as department number, asset number, or manufacturing plant location.

+

userstring.add()

+

userstring.catalog()

+

userstring.delete()

+

userstring.get()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/77377.htm b/WebHelpDocs/2601B-PULSE/77377.htm new file mode 100644 index 0000000..3dbc81d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/77377.htm @@ -0,0 +1,64 @@ + + + + + TSP-Link + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP-Link

+

These functions and attributes allow you to set up and work with a system that is connected by a TSP-Link® network.

+

tsplink.group

+

tsplink.master

+

tsplink.node

+

tsplink.readbit()

+

tsplink.readport()

+

tsplink.reset()

+

tsplink.state

+

tsplink.trigger[N].assert()

+

tsplink.trigger[N].clear()

+

tsplink.trigger[N].EVENT_ID

+

tsplink.trigger[N].mode

+

tsplink.trigger[N].overrun

+

tsplink.trigger[N].pulsewidth

+

tsplink.trigger[N].release()

+

tsplink.trigger[N].reset()

+

tsplink.trigger[N].stimulus

+

tsplink.trigger[N].wait()

+

tsplink.writebit()

+

tsplink.writeport()

+

tsplink.writeprotect

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/77502.htm b/WebHelpDocs/2601B-PULSE/77502.htm new file mode 100644 index 0000000..c012369 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/77502.htm @@ -0,0 +1,61 @@ + + + + + Digital I/O + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Digital I/O

+

The digital I/O port of the instrument can control external circuitry (such as a component handler for binning operations).

+

The I/O port has 14 lines. Each line can be at TTL logic state 1 (high) or 0 (low). See the pinout diagram in Digital I/O port for additional information.

+

There are commands to read and write to each individual bit, and commands to read and write to the entire port.

+

digio.readbit()

+

digio.readport()

+

digio.trigger[N].assert()

+

digio.trigger[N].clear()

+

digio.trigger[N].EVENT_ID

+

digio.trigger[N].mode

+

digio.trigger[N].overrun

+

digio.trigger[N].pulsewidth

+

digio.trigger[N].release()

+

digio.trigger[N].reset()

+

digio.trigger[N].stimulus

+

digio.trigger[N].wait()

+

digio.writebit()

+

digio.writeport()

+

digio.writeprotect

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/80596.htm b/WebHelpDocs/2601B-PULSE/80596.htm new file mode 100644 index 0000000..c10379e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/80596.htm @@ -0,0 +1,140 @@ + + + + + printbuffer() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

printbuffer()

+

This function prints data from tables or reading buffer subtables.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

No

+

 

+

 

+

 

+
+

Usage

+

printbuffer(startIndex, endIndex, bufferVar)

+

printbuffer(startIndex, endIndex, bufferVar, bufferVar2)

+

printbuffer(startIndex, endIndex, bufferVar, ..., bufferVarN)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

startIndex

+

Beginning index of the buffer to print; this must be more than one and less than endIndex

+

endIndex

+

Ending index of the buffer to print; this must be more than startIndex and less than the index of the last entry in the tables

+

bufferVar

+

First table or reading buffer subtable to print

+

bufferVar2

+

Second table or reading buffer subtable to print

+

bufferVarN

+

The last table or reading buffer subtable to print

+

...

+

One or more tables or reading buffer subtables separated with commas

+
+

Details

+

If startIndex ≤ 1, 1 is used as startIndex. If n < endIndex, n is used as endIndex.

+

When any given reading buffers are used in overlapped commands that have not yet completed (at least to the specified index), this function outputs data as it becomes available.

+

When there are outstanding overlapped commands to acquire data, n refers to the index that the last entry in the table has after all the measurements have completed.

+

If you pass a reading buffer instead of a reading buffer subtable, the default subtable for that reading buffer is used.

+

This command generates a single response message that contains all data. The response message is stored in the output queue.

+

The format.data attribute controls the format of the response message.

+

Example

+

+ + + + + + + + +

format.data = format.ASCII

+

format.asciiprecision = 6

+

printbuffer(1, rb1.n, rb1)

+

This assumes that rb1 is a valid reading buffer in the runtime environment. The use of rb1.n

+

(bufferVar.n) indicates that the instrument should output all readings in the reading buffer. In this example, rb1.n equals 10.

+

Example of output data (rb1.readings):

+

4.07205e-05, 4.10966e-05, 4.06867e-05, 4.08865e-05, 4.08220e-05, 4.08988e-05, 4.08250e-05, 4.09741e-05, 4.07174e-05, 4.07881e-05

+
+

Also see

+

bufferVar.n

+

bufferVar.readings

+

format.asciiprecision

+

format.byteorder

+

format.data

+

printnumber()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91672.htm b/WebHelpDocs/2601B-PULSE/91672.htm new file mode 100644 index 0000000..8649ed2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91672.htm @@ -0,0 +1,95 @@ + + + + + smua.pulser.measure.aperture + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.measure.aperture

+

This attribute specifies the pulse measurement aperture when the pulser is enabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

0.000001

+
+

Usage

+

aperture = smua.pulser.measure.aperture

+

smua.pulser.measure.aperture = aperture

+

+ + + + + + +

aperture

+

The measurement aperture; set from 0.000001 s to 0.1 s

+
+

Details

+

When using this attribute with the trigger model or in a pulse-width limited region, the sum of the measure delay and the total measure time must be less than the pulse width. The total measure time depends on the measure count, the filter count, and the measure interval.

+

The settings for this attribute are ignored if the pulser is disabled.

+

Example

+

+ + + + + + + + +

smua.pulser.measure.aperture = 10e-6

+

Set the measurement aperture to 10 µs.

+
+

Also see

+

smua.trigger.source.pulsewidth

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91673.htm b/WebHelpDocs/2601B-PULSE/91673.htm new file mode 100644 index 0000000..384f122 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91673.htm @@ -0,0 +1,104 @@ + + + + + smua.pulser.measure.delay + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.measure.delay

+

This attribute sets the measurement delay when the pulser is enabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

0

+
+

Usage

+

delay = smua.pulser.measure.delay

+

smua.pulser.measure.delay = delay

+

+ + + + + + +

delay

+

The measurement delay value in seconds; set from 0 to 0.065

+
+

Details

+

Use this attribute with the trigger model when performing a pulse sweep.

+

Set the delay parameter to a nonzero value to specify when a measurement starts during a pulse. The measurement starts after the delay interval expires. This allows the 2601B-PULSE to locate measurements within a pulse with less jitter than those generated using the measure trigger stimulus in the trigger model.

+

The sum of the measure delay and the total measure time must be less than the pulse width configured with the smua.trigger.source.pulsewidth setting. The total measure time depends on the measure count, the filter count, and the measure interval.

+

You cannot use this attribute and a measurement stimulus in the trigger model at the same time.

+

VARIABLE - CAUTION
Using both the end-pulse stimulus and this attribute in a script may cause the pulse output to end before the specified duration of the pulse is completed, causing invalid measurements.

+

When this attribute is set to zero, measurements are only triggered by a measurement stimulus.

+

The settings for this attribute are ignored if the pulser is disabled.

+

Example

+

+ + + + + + + + +

smua.pulser.measure.delay = 35e-6

+

smua.pulser.measure.aperture = 10e-6

+

Specify a 35 µs pulse measure delay and a 10 µs measurement aperture.

+
+

Also see

+

Triggering

+

smua.pulser.measure.aperture

+

smua.pulser.enable

+

smua.trigger.source.pulsewidth

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91674.htm b/WebHelpDocs/2601B-PULSE/91674.htm new file mode 100644 index 0000000..e007ef5 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91674.htm @@ -0,0 +1,96 @@ + + + + + smua.pulser.enable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.enable

+

This attribute enables or disables the 2601B-PULSE pulser.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

smua.DISABLE

+
+

Usage

+

enable = smua.pulser.enable

+

smua.pulser.enable = enable

+

+ + + + + + +

enable

+

Enable or disable the pulser; set to:

+
  • smua.DISABLE: Conventional pulsing and full source-measure unit (SMU) functionality
  • smua.ENABLE: Allow fast-edge pulsing using the trigger model
+

Details

+

When the pulser is enabled, there are the following differences in source-measure unit (SMU) functionality:

+
  • You can only source current (not voltage).
  • If the output exceeds a maximum pulse width, maximum duty cycle, or the specified protection level during a sweep, the 2601B-PULSE output is shorted, but the sweep continues with no source output until it is finished.
  • Some SMU settings are ignored; see Settings ignored when the pulser is enabled for details.
  • The smua.trigger.source.pulsewidth and smua.pulser.measure.delay attributes provide more precise timing than you can achieve using the smua.trigger.endpulse.stimulus and smua.trigger.measure.stimulus attributes.
  • Some of the output-off modes behave differently:
    • OUTPUT_NORMAL: The output circuit is shorted when this output-off mode is selected.
    • OUTPUT_ZERO: The output circuit is shorted and current cannot be measured when this output-off mode is selected.
  • You cannot use contact check.
  • You cannot make measurements when the output is off.

Example

+

+ + + + + + + + +

smua.pulser.enable = smua.ENABLE

+

Enable the pulser.

+
+

Also see

+

Pulser operation

+

smua.pulser.measure.delay

+

smua.trigger.source.pulsewidth

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91675.htm b/WebHelpDocs/2601B-PULSE/91675.htm new file mode 100644 index 0000000..e56fd05 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91675.htm @@ -0,0 +1,99 @@ + + + + + smua.pulser.protect.sensev + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.protect.sensev

+

This attribute sets a voltage protection level used to monitor the sense terminals when the pulser is enabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

20 V

+
+

Usage

+

level = smua.pulser.protect.sensev

+

smua.pulser.protect.sensev = level

+

+ + + + + + +

level

+

The voltage protection level when the pulser is enabled; the value must be between 5% and 200% of the voltage range set by the smua.pulser.rangeY attribute

+
+

Details

+

If the voltage on the sense terminals goes above the protection level, the 2601B-PULSE output is shorted for the remainder of the sweep and the output turns off at the end of the sweep.

+

The current pulse terminates within 3 µs after the remotely sensed voltage from the device under test (DUT) exceeds the specified level.

+

VARIABLE - CAUTION
Setting the protection level does not guarantee that the output will not go above the protection level. The 2601B-PULSE turns off the output as quickly as possible, but the voltage level can briefly exceed this level, potentially causing damage to the device under test (DUT).

+

The settings for this attribute are ignored if the pulser is disabled.

+

Example

+

+ + + + + + + + +

smua.pulser.protect.sensev = 8

+

Set the voltage protection limit to 8 V.

+
+

Also see

+

smua.pulser.protect.sourcev

+

smua.pulser.protect.tripped

+

smua.pulser.rangeY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91676.htm b/WebHelpDocs/2601B-PULSE/91676.htm new file mode 100644 index 0000000..22a4b22 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91676.htm @@ -0,0 +1,96 @@ + + + + + smua.pulser.protect.tripped + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.protect.tripped

+

This attribute indicates if the protection circuit was tripped.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Instrument reset
SMU reset

+

None

+

Not applicable

+
+

Usage

+

tripped = smua.pulser.protect.tripped

+

+ + + + + + +

tripped

+

The voltage protection status:

+
  • true: The protection circuit was tripped
  • false: The protection circuit was not tripped
+

Details

+

When the pulser is enabled, this attribute indicates if the protection circuit was tripped. When the protection circuit is tripped, the output is shorted and turned off.

+

The following events can trip the protection circuit:

+
  • A voltage greater than smua.pulser.protect.sensev was detected on the sense terminals.
  • A voltage greater than smua.pulser.protect.sourcev was detected on the force terminals.
  • The maximum pulse width was exceeded during trigger model operation.
  • The maximum duty cycle was exceeded during trigger model operation.
  • If the SMU cannot keep up with the pulse rate.
  • If the SMU cannot keep up with the measurement rate.

The status is reset to false when the pulser is disabled or when the output is turned on.

+

Example

+

+ + + + + + + + +

print(smua.pulser.protect.tripped)

+

Determine if the protection circuit was tripped.

+
+

Also see

+

smua.pulser.protect.sensev

+

smua.pulser.protect.sourcev

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91677.htm b/WebHelpDocs/2601B-PULSE/91677.htm new file mode 100644 index 0000000..dc3a1cc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91677.htm @@ -0,0 +1,164 @@ + + + + + smua.pulser.rangeY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.rangeY

+

This attribute sets the source and measure ranges when the pulser is enabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

Current: 10 A
Voltage: 10 V

+
+

Usage

+

range = smua.pulser.rangei

+

range = smua.pulser.rangev

+

smua.pulser.rangei = range

+

smua.pulser.rangev = range

+

+ + + + + + +

range

+

The source and measure range

+
+

Details

+

When you set a value for the range, the 2601B-PULSE automatically sets the range as appropriate for the specified value.

+

This attribute setting affects the settings that are allowed for the smua.pulser.protect.sensev attribute, which must be between 5 percent and 200 percent of the voltage range.

+

The following table lists the pulser limits for the voltage and current functions.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Voltage range

+

Source

+

Measure

+

5 V

+

Not applicable

+

5.1 V

+

10 V

+

Not applicable

+

10.2 V

+

Current ranges

+

 

+

 

+

1 A

+

±1.01 A

+

±1.02 A

+

5 A

+

±5.05 A

+

±5.1 A

+

10 A

+

±10.1 A

+

±10.2 A

+

250 mA (DC bias)

+

±250 mA

+

Selected pulse measure range

+
+

The settings for this attribute are ignored if the pulser is disabled.

+

Example

+

+ + + + + + +

smua.pulser.rangei = 1

+

Set the pulser current range to 1 A.

+
+

Also see

+

smua.pulser.protect.sensev

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91678.htm b/WebHelpDocs/2601B-PULSE/91678.htm new file mode 100644 index 0000000..806a686 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91678.htm @@ -0,0 +1,97 @@ + + + + + smua.trigger.source.pulsewidth + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.source.pulsewidth

+

This attribute sets the source pulse width when using a trigger model sweep when the pulser is enabled

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

0

+
+

Usage

+

pulsewidth = smua.trigger.source.pulsewidth

+

smua.trigger.source.pulsewidth = pulsewidth

+

+ + + + + + +

pulsewidth

+

The source pulse width in seconds; set from 0.000001 to 0.065; set to 0 to disable automatic pulsewidth control

+
+

Details

+

Use this attribute only when generating pulses using the trigger model when the pulser is enabled.

+

Set the pulsewidth parameter to a nonzero value to limit the action of the source to the specified pulse width. This allows the 2601B-PULSE to generate pulses with less pulsewidth jitter than those generated using the end-pulse trigger block in the trigger model.

+

The value set for this attribute affects the values you can use for the smua.pulser.measure.aperture and smu.pulser.measure.delay attributes. The sum of the measure delay and the aperture must be less than the specified pulse width.

+

You cannot use this attribute and smua.trigger.endpulse.action in the same trigger model.

+

Example

+

+ + + + + + +

smua.trigger.source.pulsewidth = 50e-6

+

Set the source pulse width to 50 µs.

+
+

Also see

+

smua.pulser.measure.aperture

+

smua.pulser.measure.delay

+

smua.trigger.endpulse.action

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91702.htm b/WebHelpDocs/2601B-PULSE/91702.htm new file mode 100644 index 0000000..edcafb8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91702.htm @@ -0,0 +1,43 @@ + + + + + Settings ignored when the pulser is disabled + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Settings ignored when the pulser is disabled

+

The following pulser settings do not affect source-measure unit (SMU) operation when the pulser is disabled:

+
  • smua.pulser.measure.aperture
  • smua.pulser.measure.delay
  • smua.pulser.protect.sensev
  • smua.pulser.protect.sourcev
  • smua.pulser.rangeY
+ + + +
+

See also

TSP command programming notes

Placeholder text

Syntax rules

Time and date values

Settings ignored when the pulser is enabled

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91895.htm b/WebHelpDocs/2601B-PULSE/91895.htm new file mode 100644 index 0000000..ffa0b77 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91895.htm @@ -0,0 +1,132 @@ + + + + + smua.pulser.measure.calibrateY() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.measure.calibrateY()

+

This function generates and activates new measurement calibration constants for the pulser.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.pulser.measure.calibrateY(range, cp1Measured, cp1Reference, cp2Measured, cp2Reference)

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + +

range

+

The pulse measurement range to adjust

+

Y

+

The measurement function (v = voltage, i = current)

+

cp1Measured

+

The value measured by this SMU for point 1

+

cp1Reference

+

The reference measurement for point 1 as measured externally

+

cp2Measured

+

The value measured by this SMU for point 2

+

cp2Reference

+

The reference measurement for point 2 as measured externally

+
+

Details

+

This function generates and activates new calibration constants for the given range.

+

The positive and negative polarities of the instrument must be adjusted separately. Use a positive value for range to adjust the positive polarity and a negative value for range to adjust the negative polarity.

+

Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.

+

The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.

+

This function is only available when calibration is unlocked using smua.cal.unlock().

+

Example

+

+ + + + + + + + +

smua.pulser.measure.calibratei(1, 0.01, 0.011, 0.75, 0.76)

+

Adjusts the current measurement using the following values:

+
  • 1 A measurement range
  • 0.01 for the +zero measurement reading
  • 0.011 for the +zero DMM measurement reading
  • 0.75 for the + full-scale measurement reading
  • 0.76 for the + full-scale DMM measurement reading
+

Also see

+

Calibration

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+

smua.pulser.source.calibratebiasi()

+

smua.pulser.source.calibratei()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91897.htm b/WebHelpDocs/2601B-PULSE/91897.htm new file mode 100644 index 0000000..7f2fd2e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91897.htm @@ -0,0 +1,125 @@ + + + + + smua.pulser.source.calibratebiasi() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.source.calibratebiasi()

+

This function generates and activates new bias source calibration constants for the pulser.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.pulser.source.calibratebiasi(range, cp1Expected, cp1Reference, cp2Expected, cp2Reference)

+

+ + + + + + + + + + + + + + + + + + + + + + +

range

+

The pulser bias current range to adjust

+

cp1Expected

+

The source value set for point 1

+

cp1Reference

+

The reference measurement for point 1 as measured externally

+

cp2Expected

+

The source value set for point 2

+

cp2Reference

+

The reference measurement for point 2 as measured externally

+
+

Details

+

The positive and negative polarities must be adjusted separately. To adjust the positive polarity, use the +250e-3 range; to adjust the negative polarity, use the -250e-3 range.

+

Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.

+

The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.

+

This function is only available when calibration is unlocked using smua.cal.unlock().

+

Example

+

+ + + + + + + + +

smua.pulser.source.calibratebiasi(250e-3, 1e-10, 1e-5, 0.224, 0.225)

+

Adjusts the bias source calibration constant for the 250e-3 pulser range using 1e-10 as the source value and 1e-5 for the reference measurement for point 1 and 0.224 as the source value and 0.225 as the reference measurement for point 2.

+
+

Also see

+

Calibration

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+

smua.pulser.measure.calibrateY()

+

smua.pulser.source.calibratei()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91898.htm b/WebHelpDocs/2601B-PULSE/91898.htm new file mode 100644 index 0000000..78ec714 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91898.htm @@ -0,0 +1,126 @@ + + + + + smua.pulser.source.calibratei() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.source.calibratei()

+

This function generates and activates new source calibration constants for the pulser.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.pulser.source.calibratei(range, cp1Expected, cp1Reference, cp2Expected, cp2Reference)

+

+ + + + + + + + + + + + + + + + + + + + + + +

range

+

The pulser current range to adjust

+

cp1Expected

+

The source value set for point 1

+

cp1Reference

+

The reference measurement for point 1 as measured externally

+

cp2Expected

+

The source value set for point 2

+

cp2Reference

+

The reference measurement for point 2 as measured externally

+
+

Details

+

This function generates and activates new calibration constants for the given range.

+

Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.

+

The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.

+

This function is only available when calibration is unlocked using smua.cal.unlock().

+

Example

+

+ + + + + + + + +

smua.pulser.source.calibratei(1, 1e-10, 1e-5, 0.9, 0.903)

+

Generates and activates new source calibration constants for the pulser 1 A range. For point 1, it uses 1e-10 as the source value and 1e-5 as the reference measurement. For point 2, it uses 0.9 for the source value and 0.903 for the reference measurement.

+
+

Also see

+

Calibration

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.unlock()

+

smua.pulser.measure.calibrateY()

+

smua.pulser.source.calibratebiasi()

+

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/91979.htm b/WebHelpDocs/2601B-PULSE/91979.htm new file mode 100644 index 0000000..ca1f155 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/91979.htm @@ -0,0 +1,43 @@ + + + + + Settings ignored when the pulser is enabled + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Settings ignored when the pulser is enabled

+

The following source-measure unit (SMU) settings are ignored when the pulser is enabled:

+
  • display.smua.limit.func
  • smua.measure.autorangeY
  • smua.measure.autozero
  • smua.measure.delay
  • smua.measure.highcrangedelayfactor
  • smua.measure.lowrangeY
  • smua.measure.nplc
  • smua.measure.rangeY
  • smua.sense
  • smua.source.autorangeY
  • smua.source.delay
  • smua.source.func
  • smua.source.highc
  • smua.source.limitY
  • smua.source.lowrangeY
  • smua.source.offlimitY
  • smua.source.rangeY
  • smua.source.settling
  • smua.source.sink
  • smua.trigger.endpulse.action
  • smua.trigger.endsweep.action
+ + + +
+

See also

TSP command programming notes

Placeholder text

Syntax rules

Time and date values

Settings ignored when the pulser is disabled

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92073.htm b/WebHelpDocs/2601B-PULSE/92073.htm new file mode 100644 index 0000000..1cd40f2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92073.htm @@ -0,0 +1,92 @@ + + + + + display.smua.digits + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.smua.digits

+

This attribute sets the front-panel display resolution of the selected measurement.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Saved setup

+

5 (display.DIGITS_5_5)

+
+

Usage

+

digits = display.smua.digits

+

display.smua.digits = digits

+

+ + + + + + +

digits

+

Set digits to one of the following values:

+
  • Select 4-1/2 digit resolution (4 or display.DIGITS_4_5)
  • Select 5-1/2 digit resolution (5 or display.DIGITS_5_5)
  • Select 6-1/2 digit resolution (6 or display.DIGITS_6_5)
+

Details

+

This attribute sets the display resolution.

+

Example

+

+ + + + + + +

display.smua.digits = display.DIGITS_5_5

+

Select 5-1/2 digit resolution.

+
+

Also see

+

Display resolution

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92074.htm b/WebHelpDocs/2601B-PULSE/92074.htm new file mode 100644 index 0000000..4523ea0 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92074.htm @@ -0,0 +1,93 @@ + + + + + display.smua.limit.func + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.smua.limit.func

+

This attribute specifies the type of limit value setting displayed for the SMU.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Saved setup

+

0 (display.LIMIT_IV)

+
+

Usage

+

func = display.smua.limit.func

+

display.smua.limit.func = func

+

+ + + + + + +

func

+

One of the following values:

+
  • 0 or display.LIMIT_IV: Displays the primary limit setting
  • 1 or display.LIMIT_P: Displays the power limit setting
+

Details

+

Selects the displayed limit function for the SMU: primary (IV) or power (P).

+

Example

+

+ + + + + + +

display.smua.limit.func = display.LIMIT_P

+

Specifies that the power limit value is displayed.

+
+

Also see

+

display.smua.measure.func

+

Display mode

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92075.htm b/WebHelpDocs/2601B-PULSE/92075.htm new file mode 100644 index 0000000..4deb607 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92075.htm @@ -0,0 +1,92 @@ + + + + + display.smua.measure.func + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.smua.measure.func

+

This attribute specifies the type of measurement that is being displayed.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Saved setup

+

1 (display.MEASURE_DCVOLTS)

+
+

Usage

+

func = display.smua.measure.func

+

display.smua.measure.func = func

+

+ + + + + + +

func

+

The type of measurement:

+
  • 0 or display.MEASURE_DCAMPS: Current measurement function
  • 1 or display.MEASURE_DCVOLTS: Voltage measurement function
  • 2 or display.MEASURE_OHMS: Resistance measurement function
  • 3 or display.MEASURE_WATTS: Power measurement function
+

Details

+

Selects the measurement function that is displayed on the front panel: Amps, volts, ohms, or watts.

+

Example

+

+ + + + + + +

display.smua.measure.func = display.MEASURE_DCAMPS

+

Selects the current measure function.

+
+

Also see

+

display.smua.limit.func

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92127.htm b/WebHelpDocs/2601B-PULSE/92127.htm new file mode 100644 index 0000000..a4d1213 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92127.htm @@ -0,0 +1,47 @@ + + + + + Display mode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Display mode

+

Use the DISPLAY key to scroll through the display modes shown in the figure below.

+

Display modes when the pulser is disabled

+

+

Display modes when the pulser is enabled

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92241.htm b/WebHelpDocs/2601B-PULSE/92241.htm new file mode 100644 index 0000000..ab4361e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92241.htm @@ -0,0 +1,101 @@ + + + + + smua.measure.delay + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.delay

+

This attribute controls the measurement delay.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

0 (smua.DELAY_OFF)

+

 

+
+

Usage

+

mDelay = smua.measure.delay

+

smua.measure.delay = mDelay

+

+ + + + + + +

mDelay

+

Set to the measurement delay value in seconds (for example, to specify an additional 10 ms measurement delay, set the value to 0.010)

+

You can also set it to one of the following values:

+
  • 0 or smua.DELAY_OFF: No delay
  • -1 or smua.DELAY_AUTO: Automatic delay value
+

Details

+

This attribute allows for additional delay (settling time) before making a measurement. If you define the value instead of using the automatic delay value, the delay you set is used regardless of the range.

+

The smua.DELAY_AUTO setting causes a current range-dependent delay to be inserted when a current measurement is requested. This happens when a current measurement command is executed, when the measure action is being performed in a sweep, or after changing ranges during an autoranged measurement.

+

If smua.measure.count is greater than 1, the measurement delay is only inserted before the first measurement.

+

Example

+

+ + + + + + +

smua.measure.delay = 0.010

+

Sets a 10 ms measurement delay.

+
+

Also see

+

Measure auto delay

+

reset()

+

smua.measure.count

+

smua.measure.delayfactor

+

smua.source.delay

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92282.htm b/WebHelpDocs/2601B-PULSE/92282.htm new file mode 100644 index 0000000..a9e7563 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92282.htm @@ -0,0 +1,94 @@ + + + + + display.screen + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.screen

+

This attribute contains the selected display screen.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
Recall setup

+

Saved setup

+

0 (display.SMUA)

+
+

+

Usage

+

displayID = display.screen

+

display.screen = displayID

+

+ + + + + + +

displayID

+

One of the following values:

+
  • 0 or display.SMUA: Displays source-measure and compliance values
  • 3 or display.USER: Displays the user screen
+

Details

+

Setting this attribute selects the display screen for the front panel. This performs the same action as pressing the DISPLAY key on the front panel. The text for the display screen is set by display.settext().

+

Read this attribute to determine which of the available display screens was last selected.

+

Example

+

+ + + + + + +

display.screen = display.SMUA

+

Selects the source-measure and compliance limit display.

+
+

Also see

+

display.settext()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92304.htm b/WebHelpDocs/2601B-PULSE/92304.htm new file mode 100644 index 0000000..0cecf11 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92304.htm @@ -0,0 +1,44 @@ + + + + + TSP-Link trigger lines + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

TSP-Link trigger lines

+

The 2601B-PULSE has three trigger lines that you can use for triggering, digital I/O, and to synchronize multiple instruments on a TSP-Link® network.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92312.htm b/WebHelpDocs/2601B-PULSE/92312.htm new file mode 100644 index 0000000..632a962 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92312.htm @@ -0,0 +1,106 @@ + + + + + smua.source.rangeY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.rangeY

+

This attribute contains the source range.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

Voltage: 100e-3 (100 mV)
Current: 100e-9 (100 nA)

+
+

Usage

+

rangeValue = smua.source.rangeY

+

smua.source.rangeY = rangeValue

+

+ + + + + + + + + + +

rangeValue

+

Set to the maximum expected voltage or current to be sourced

+

Y

+

SMU source function (v = voltage, i = current)

+
+

Details

+

This attribute contains a value that sets the source-measure unit (SMU) to a fixed range large enough to source the value. When read, the attribute contains the range the instrument is presently on when in autorange.

+

Assigning a value to this attribute sets the SMU to a fixed range large enough to source the assigned value. The instrument selects the best range for sourcing a value of rangeValue.

+

Reading this attribute returns the positive full-scale value of the source range the SMU is currently using. With source autoranging enabled, the output level controls the range. Querying the range after the level is set returns the range the instrument chose as appropriate for that source level.

+

This attribute is primarily intended to eliminate the time required by the automatic range selection performed by a sourcing instrument. Because selecting a fixed range prevents autoranging, an overrange condition can occur. For example, sourcing 10.0 V on the 2601B-PULSE 6 V range causes an overrange condition.

+

Example

+

+ + + + + + +

smua.source.rangev = 1

+

Selects the 1 V source range.

+
+

Also see

+

Range

+

reset()

+

setup.recall()

+

smua.measure.rangeY

+

smua.reset()

+

smua.source.autorangeY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92317.htm b/WebHelpDocs/2601B-PULSE/92317.htm new file mode 100644 index 0000000..cff07a1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92317.htm @@ -0,0 +1,110 @@ + + + + + smua.measure.rangeY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.rangeY

+

This attribute contains the positive full-scale value of the measurement range for voltage or current.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

Voltage: 100e-3 (100 mV)
Current: 100e-3 (100 mA)

+
+

Usage

+

rangeValue = smua.measure.rangeY

+

smua.measure.rangeY = rangeValue

+

+ + + + + + + + + + +

rangeValue

+

Set to the maximum expected voltage or current to be measured

+

Y

+

SMU measurement function (v = voltage, i = current)

+
+

Details

+

Reading this attribute returns the positive full-scale value of the measurement range that the SMU is currently using. Assigning a value to this attribute sets the SMU on a fixed range large enough to measure the assigned value. The instrument will select the best range for measuring a value of rangeValue.

+

This attribute is primarily intended to eliminate the time that is required by the automatic range selection performed by a measuring instrument. Because selecting a fixed range prevents autoranging, an overrange condition can occur. For example, measuring 10.0 V on the 6 V range causes an overrange. The value 9.91000E+37 is returned when this occurs.

+

If the source function is the same as the measurement function (for example, sourcing voltage and measuring voltage), the measurement range is locked to be the same as the source range. However, the setting for the measure range is retained. If the source function is changed (for example, from sourcing voltage to sourcing current), the retained measurement range is used.

+

For example, assume the source function is voltage. The source range is 1 V and you set the measure range for 6 V. Since the source range is 1 V, the SMU performs voltage measurements on the 1 V range. If you now change the source function to current, voltage measurements are made on the 6 V range.

+

Explicitly setting a measure range will disable measure autoranging for that function. Autoranging is controlled separately for each source and measurement function: source voltage, source current, measure voltage and measure current. Autoranging is enabled for all four by default.

+

Changing the range while the output is off does not update the hardware settings, but querying returns the range setting that will be used once the output is turned on. Setting a range while the output is on takes effect immediately.

+

With measure autoranging enabled, the range is changed only when a measurement is taken. Querying the range after a measurement returns the range selected for that measurement.

+

Example

+

+ + + + + + +

smua.measure.rangev = 0.5

+

Selects the 1 V measurement range.

+
+

Also see

+

Range

+

reset()

+

setup.recall()

+

smua.measure.autorangeY

+

smua.pulser.rangeY

+

smua.reset()

+

smua.source.rangeY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92325.htm b/WebHelpDocs/2601B-PULSE/92325.htm new file mode 100644 index 0000000..09fde60 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92325.htm @@ -0,0 +1,171 @@ + + + + + errorqueue.next() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

errorqueue.next()

+

This function reads the oldest entry from the error queue and removes it from the queue.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

errorCode, message, severity, errorNode = errorqueue.next()

+

+ + + + + + + + + + + + + + + + + + +

errorCode

+

The error code number for the entry

+

message

+

The message that describes the error code

+

severity

+

The severity level (0, 10, 20, 30, or 40); see Details for more information

+

errorNode

+

The node number where the error originated

+
+

Details

+

Entries are stored in a first-in, first-out (FIFO) queue. This function reads the oldest entry and removes it from the queue.

+

Error codes and messages are listed in the Error summary list.

+

If there are no entries in the queue, code 0, "Queue is Empty" is returned.

+

Returned severity levels are described in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Number

+

Error level

+

Description

+

0

+

NO_SEVERITY

+

The message is information only. This level is used when the Error Queue is empty; the message does not represent an error.

+

10

+

INFORMATIONAL

+

The message is information only. This level is used to indicate status changes; the message does not represent an error.

+

20

+

RECOVERABLE

+

The error was caused by improper use of the instrument or by conditions that can be corrected. This message indicates that an error occurred. The instrument is still operating normally.

+

30

+

SERIOUS

+

There is a condition that prevents the instrument from functioning properly. The message indicates that the instrument is presently operating in an error condition. If the condition is corrected, the instrument will return to normal operation.

+

40

+

FATAL

+

There is a condition that cannot be corrected that prevents the instrument from functioning properly. Disconnect the DUT and turn the power off and then on again. If the error is a hardware fault that persists after cycling the power, the instrument must be repaired.

+
+

In an expanded system, each TSP-Link enabled instrument is assigned a node number. The variable errorNode stores the node number where the error originated.

+

Example

+

+ + + + + + +

errorcode, message = errorqueue.next()

+

print(errorcode, message)

+

Reads the oldest entry in the error queue. The output below indicates that the queue is empty.

+

Output:

+

0.00000e+00 Queue Is Empty

+
+

Also see

+

Error queue

+

errorqueue.clear()

+

errorqueue.count

+

Error summary list

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92333.htm b/WebHelpDocs/2601B-PULSE/92333.htm new file mode 100644 index 0000000..4756b15 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92333.htm @@ -0,0 +1,103 @@ + + + + + smua.measure.lowrangeY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.lowrangeY

+

This attribute sets the lowest measurement range that is used when the instrument is autoranging.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

Current: 100e-9 (100 nA)
Voltage: 100e-3 (100 mV)

+
+

Usage

+

lowRange = smua.measure.lowrangeY

+

smua.measure.lowrangeY = lowRange

+

+ + + + + + + + + + +

lowRange

+

The lowest voltage or current measurement range used during autoranging

+

Y

+

SMU measure function (v = voltage, i = current)

+
+

Details

+

This attribute is used with autoranging to put a lower bound on the range used. Since lower ranges generally require greater settling times, setting a lowest range limit might make measurements require less settling time.

+

If the instrument is set to autorange and it is on a range lower than the one specified, the range is changed to the lowRange range value.

+

Example

+

+ + + + + + +

smua.measure.lowrangev = 1

+

Sets voltage low range to 1 V.

+
+

Also see

+

Range

+

reset()

+

setup.recall()

+

smua.measure.autorangeY

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92343.htm b/WebHelpDocs/2601B-PULSE/92343.htm new file mode 100644 index 0000000..cc0f2a2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92343.htm @@ -0,0 +1,94 @@ + + + + + smua.source.settling + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.settling

+

This attribute contains the source settling mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

0 (smua.SETTLE_SMOOTH)

+
+

Usage

+

settleOption = smua.source.settling

+

smua.source.settling = settleOption

+

+ + + + + + +

settleOption

+

Set to the source settling mode. Set to one of the following values:

+
  • 0 or smua.SETTLE_SMOOTH: Turns off additional settling operations (default)
  • 1 or smua.SETTLE_FAST_RANGE: Instructs the source-measure unit (SMU) to use a faster procedure when changing ranges
  • 2 or smua.SETTLE_FAST_POLARITY: Instructs the SMU to change polarity without going to zero
  • 3 or smua.SETTLE_DIRECT_IRANGE: Instructs the SMU to change the current range directly
  • 128 or smua.SETTLE_FAST_ALL: Enables all smua.SETTLE_FAST_* operations
+

Details

+

Using smua.SETTLE_FAST_RANGE may cause the SMU to exceed the range change overshoot specification.

+

smua.SETTLE_FAST_POLARITY does not go to zero when changing polarity and may create inconsistencies at the zero crossing.

+

smua.SETTLE_DIRECT_IRANGE switches the SMU directly to the target range instead of the default range-by-range method. This option is mutually exclusive of any other smua.SETTLE_FAST_* commands.

+

Example

+

+ + + + + + +

smua.source.settling = smua.SETTLE_FAST_POLARITY

+

Selects fast polarity changing.

+
+

Also see

+

Range

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92358.htm b/WebHelpDocs/2601B-PULSE/92358.htm new file mode 100644 index 0000000..375cc48 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92358.htm @@ -0,0 +1,99 @@ + + + + + smua.source.lowrangeY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.lowrangeY

+

This attribute sets the lowest source range that is used during autoranging.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

Voltage: 100e-3 (100 mV)
Current: 100e-9 (100 nA)

+
+

Usage

+

sourceRangeLow = smua.source.lowrangeY

+

smua.source.lowrangeY = sourceRangeLow

+

+ + + + + + + + + + +

sourceRangeLow

+

Set to the lowest voltage (in volts) or current (in amperes) range to be used

+

Y

+

SMU source function (v = voltage, i = current)

+
+

Details

+

This attribute is used with source autoranging to put a lower bound on the range that is used. Lower ranges generally require greater settling times. If you set a low-range value, you might be able to source small values with less settling time.

+

If the instrument is set to autorange and it is on a range lower than the one specified by sourceRangeLow, the source range will be changed to the range specified by sourceRangeLow.

+

Example

+

+ + + + + + +

smua.source.lowrangev = 1

+

Sets the voltage low range to 1 V. This prevents the source from using the 100 mV range when sourcing voltage.

+
+

Also see

+

smua.source.autorangeY

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92359.htm b/WebHelpDocs/2601B-PULSE/92359.htm new file mode 100644 index 0000000..ce3ee6f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92359.htm @@ -0,0 +1,105 @@ + + + + + smua.source.limitY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.limitY

+

This attribute sets compliance limits.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

Limit voltage: 40 (40 V)
Limit current: 1 (1 A)
Limit power: 0 (disabled)

+
+

Usage

+

limit = smua.source.limitY

+

smua.source.limitY = limit

+

+ + + + + + + + + + +

limit

+

The compliance limit value; set to one of the following values:

+
  • Voltage compliance: 10 mV to 40 V
  • Current compliance: 10 nA to 3 A
  • Power compliance (in watts)

Y

+

SMU function (v = voltage, i = current, p = power)

+
+

Details

+

Use the smua.source.limiti attribute to limit the current output of the voltage source. Use smua.source.limitv to limit the voltage output of the current source. The SMU always uses autoranging for the limit setting. Use the smua.source.limitp attribute to limit the output power of the source.

+

This attribute should be set in the test sequence before the turning the source on.

+

Using a limit value of 0 results in error code 1102, "Parameter too small," for v and i. Setting this attribute to zero disables power compliance for p. When setting the power compliance limit to a nonzero value, the SMU adjusts the source limit where appropriate to limit the output to the specified power. The SMU uses the lower of the programmed compliance value (the compliance level that would be used if power compliance were disabled) or the limit calculated from the power compliance setting.

+

Reading this attribute indicates the presently set compliance value. Use smua.source.compliance to read the state of source compliance.

+

Example

+

+ + + + + + +

smua.source.limitv = 15

+

Sets the voltage limit to 15 V.

+
+

Also see

+

DUT test connections

+

smua.source.compliance

+

smua.source.func

+

smua.source.output

+

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92361.htm b/WebHelpDocs/2601B-PULSE/92361.htm new file mode 100644 index 0000000..f7be597 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92361.htm @@ -0,0 +1,106 @@ + + + + + smua.source.levelY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.levelY

+

This attribute sets the source level.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

0

+
+

Usage

+

sourceLevel = smua.source.levelY

+

smua.source.levelY = sourceLevel

+

+ + + + + + + + + + +

sourceLevel

+

The source value; set to one of the following values:

+
  • Voltage: 0 V to ±40 V
  • Current when the pulser is disabled: 0 A to ±3 A
  • Bias current when the pulser is enabled: 0 A to ±250 mA

Y

+

SMU source function (v = voltage, i = current)

+
+

Details

+

This attribute configures the output level of the voltage or current source.

+

If the source is configured as a voltage source and the output is on, the new smua.source.levelv setting is sourced immediately. If the output is off or the source is configured as a current source, the voltage level is sourced when the source is configured as a voltage source and the output is turned on.

+

If the source is configured as a current source and the output is on, the new smua.source.leveli setting is sourced immediately. If the output is off or the source is configured as a voltage source, the current level is sourced when the source is configured as a current source and the output is turned on.

+

The sign of sourceLevel dictates the polarity of the source. Positive values generate positive voltage or current from the high terminal of the source relative to the low terminal. Negative values generate negative voltage or current from the high terminal of the source relative to the low terminal.

+

The reset() function sets the source levels to 0 V and 0 A.

+

Example

+

+ + + + + + +

smua.source.levelv = 1

+

Sets voltage source of SMU channel A to 1 V.

+
+

Also see

+

smua.source.compliance

+

smua.source.func

+

smua.source.output

+

Source-measure concepts

+

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92390.htm b/WebHelpDocs/2601B-PULSE/92390.htm new file mode 100644 index 0000000..1213d47 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92390.htm @@ -0,0 +1,547 @@ + + + + + status.measurement.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.*

+

This attribute contains the measurement event register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

10,635 (All bits set)

+
+

+

Usage

+

measurementRegister = status.measurement.condition

+

measurementRegister = status.measurement.enable

+

measurementRegister = status.measurement.event

+

measurementRegister = status.measurement.ntr

+

measurementRegister = status.measurement.ptr

+

status.measurement.enable = measurementRegister

+

status.measurement.ntr = measurementRegister

+

status.measurement.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the measurement event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes read or write the measurement event registers.

+

Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For example, assume value 257 is returned for the enable register. The binary equivalent is 0000 0001 0000 0001. This value indicates that bit B0 (VLMT) and bit B8 (BAV) are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.measurement.VOLTAGE_LIMIT

+

status.measurement.VLMT

+

Set bit is a summary of the status.measurement.voltage_limit register.

+

Bit B0 decimal value: 1

+

B1

+

status.measurement.CURRENT_LIMIT

+

status.measurement.ILMT

+

Set bit is a summary of the status.measurement.current_limit register.

+

Bit B1 decimal value: 2

+

B2

+

Not used

+

B3

+

status.measurement.PROTECTION

+

status.measurement.PROT

+

Set bit indicates that the pulser protection was tripped. Refer to smua.pulser.protect.tripped for events that can trip the protection circuits.

+

Bit B1 decimal value: 8

+

B4 to B6

+

Not used

+

B7

+

status.measurement.READING_OVERFLOW

+

status.measurement.ROF

+

Set bit is a summary of the status.measurement.reading_overflow register.

+

Bit B7 decimal value: 128

+

B8

+

status.measurement.BUFFER_AVAILABLE

+

status.measurement.BAV

+

Set bit is a summary of the status.measurement.buffer_available register.

+

Bit B8 decimal value: 256

+

B9 to B10

+

Not used

+

B11

+

status.measurement.INTERLOCK

+

status.measurement.INT

+

Interlock line. Set bit indicates that interlock is asserted.

+

Bit B11 decimal value: 2,048

+

B12

+

Not used

+

B13

+

status.measurement.INSTRUMENT_SUMMARY

+

status.measurement.INST

+

Set bit indicates that a bit in the measurement instrument summary register is set.

+

Bit B13 decimal value: 8,192

+

B14 to B15

+

Not used

+
+

As an example, to set bit B8 of the measurement event enable register, set status.measurement.enable = status.measurement.BAV.

+

In addition to the above constants, measurementRegister can be set to the decimal equivalent of the bit to set. To set more than one bit of the register, set measurementRegister to the sum of their decimal weights. For example, to set bits B1 and B8, set measurementRegister to 258 (which is the sum of 2 + 256).

+

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example

+

+ + + + + + + + +

status.measurement.enable = status.measurement.BAV

+

Sets the BAV bit of the measurement event enable register.

+
+

Also see

+

Measurement event registers

+

smua.pulser.protect.tripped

+

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92460.htm b/WebHelpDocs/2601B-PULSE/92460.htm new file mode 100644 index 0000000..108282f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92460.htm @@ -0,0 +1,60 @@ + + + + + Placeholder text + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Placeholder text

+

This manual uses italicized text to represent the parts of remote commands that must be replaced by user specified values. The following examples show typical uses of italicized text:

+

Example 1:

+

beeper.enable = state

+

Where state can be a value (beeper.ON or beeper.OFF) or an integer (1 or 0) that you specify. For example, to set this attribute on, you would send one of the following commands:

+

beeper.enable = beeper.ON

+

beeper.enable = 1

+

Example 2:

+

digio.trigger[N].assert()

+

Where N is an integer (1 to 14) that you specify. For example, to assert trigger line 7 you would send:

+

digio.trigger[7].assert()

+

To assert a trigger line with a variable as the integer, you would send:

+

triggerline = 7

+

digio.trigger[triggerline].assert()

+

Example 3:

+

smua.trigger.measure.Y(rbuffer)

+

Where:

+
  • Y is the measurement type that you specify (v, i, r, or p).
  • rbuffer is the reading buffer object where the readings will be stored.

For example, to make voltage measurements and store them in buffer vbuffername, you would send:

+

smua.trigger.measure.v(vbuffername)

+ + + + +
+

See also

TSP command programming notes

Syntax rules

Time and date values

Settings ignored when the pulser is enabled

Settings ignored when the pulser is disabled

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92517.htm b/WebHelpDocs/2601B-PULSE/92517.htm new file mode 100644 index 0000000..439aa42 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92517.htm @@ -0,0 +1,91 @@ + + + + + smua.contact.check() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.contact.check()

+

This function determines if contact resistance is lower than the threshold.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

smua.contact.check()

+

Details

+

VARIABLE - NOTE
Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser. See Example 1: Ten-point pulse sweep for a code example.

+

This function returns true if the contact resistance is below the threshold; this function returns false if it is above the threshold. The threshold value is set by the smua.contact.threshold attribute.

+

When the output is on and any of the following:

+
  • SMU is a current source with current range set to less than 1 mA (error code 5065, "I range too low for contact check")
  • SMU is a voltage source with current limit set to less than 1 mA (error code 5050, "I limit too low for contact check")

When the output is off and any of the following:

+
  • The output off mode is High-Z (error code 5048, "Contact check not valid with HIGH-Z OUTPUT off")
  • The output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCVOLTS and the off current limit set to less than 1 mA (error code 5066, "source.offlimiti too low for contact check")
  • The output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCAMPS and the source range is less than 1 mA (error code 5065, "I range too low for contact check")

If you attempt to perform a contact check measurement when any of the above conditions exist, an error is generated.

+

Example

+

+ + + + + + +

if not smua.contact.check() then

+

-- take action

+

end

+

Takes action if contact check fails.

+
+

Also see

+

Contact check connections

+

Contact check measurements

+

smua.contact.speed

+

smua.contact.threshold

+

smua.source.offfunc

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92519.htm b/WebHelpDocs/2601B-PULSE/92519.htm new file mode 100644 index 0000000..08f4460 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92519.htm @@ -0,0 +1,99 @@ + + + + + smua.contact.speed + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.contact.speed

+

This attribute stores the speed setting for contact check measurements.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Not saved

+

0 (smua.CONTACT_FAST)

+
+

Usage

+

speedSetting = smua.contact.speed

+

smua.contact.speed = speedSetting

+

+ + + + + + +

speedSetting

+

The speed setting. Set to one of the following:

+
  • 0 or smua.CONTACT_FAST
  • 1 or smua.CONTACT_MEDIUM
  • 2 or smua.CONTACT_SLOW
+

Details

+

This setting controls the aperture of measurements made for contact check. It does not affect the smua.measure.nplc aperture setting.

+

The speed setting can have a dramatic effect on the accuracy of the measurement (see the specifications).

+

VARIABLE - NOTE
Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser.

+

Example

+

+ + + + + + +

smua.contact.speed = smua.CONTACT_SLOW

+

Configure contact check for higher accuracy.

+
+

Also see

+

Contact check connections

+

Contact check measurements

+

reset()

+

smua.contact.check()

+

smua.contact.r()

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92520.htm b/WebHelpDocs/2601B-PULSE/92520.htm new file mode 100644 index 0000000..7fc48e8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92520.htm @@ -0,0 +1,99 @@ + + + + + smua.contact.threshold + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.contact.threshold

+

This attribute stores the resistance threshold for the smua.contact.check() function.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Not saved

+

50 (50 Ω)

+
+

Usage

+

rValue = smua.contact.threshold

+

smua.contact.threshold = rValue

+

+ + + + + + +

rValue

+

The resistance above which contact check should fail (measured in ohms)

+
+

Details

+

The threshold should be set to less than 1 kΩ.

+

VARIABLE - NOTE
Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser.

+

Example

+

+ + + + + + + + +

smua.contact.threshold = 5

+

Set the contact check threshold to 5 Ω.

+
+

Also see

+

Contact check connections

+

Contact check measurements

+

reset()

+

smua.contact.check()

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92521.htm b/WebHelpDocs/2601B-PULSE/92521.htm new file mode 100644 index 0000000..92220a1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92521.htm @@ -0,0 +1,102 @@ + + + + + smua.source.offmode + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.offmode

+

This attribute sets the source output-off mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

0 (smua.OUTPUT_NORMAL)

+
+

Usage

+

sourceOffMode = smua.source.offmode

+

smua.source.offmode = sourceOffMode

+

+ + + + + + +

sourceOffMode

+

The output-off setting; set to one of the following values:

+
  • 0 or smua.OUTPUT_NORMAL: See Details
  • 1 or smua.OUTPUT_ZERO: See Details
  • 2 or smua.OUTPUT_HIGH_Z: Opens the output relay when the output is turned off
+

+

Details

+

Reading this attribute returns the output-off mode of the source. Setting this attribute configures the SMU output-off mode.

+

When smua.OUTPUT_NORMAL is selected and the pulser is disabled, the source function is configured according to the smua.source.offfunc attribute. The smua.source.offfunc attribute controls whether the SMU is configured as a 0 V voltage source or a 0 A current source. When the SMU is operating as a 0 A current source, the smua.source.offlimitv attribute sets the voltage limit (similar to how the smua.source.offlimiti attribute sets the current limit when the SMU is operating as a 0 V voltage source).

+

When the output-off mode is set to smua.OUTPUT_ZERO and the pulser is disabled, the source is configured to output 0 V. This is equivalent to smua.OUTPUT_NORMAL mode with smua.source.offfunc = smua.OUTPUT_DCVOLTS. If the source function is voltage, the current limit is not changed. If the source function is current, the current limit is set to the current source level or 10% of the current source range, whichever is greater.

+

When smua.OUTPUT_NORMAL or smua.OUTPUT_ZERO is selected and the pulser is enabled, the output circuit is shorted.

+

When sourceOffMode is set to smua.OUTPUT_HIGH_Z, the SMU opens the output relay when the output is turned off. To prevent excessive wear on the output relay, do not use this output-off mode for tests that turn the output off and on frequently.

+

Example

+

+ + + + + + + + +

smua.source.offmode = smua.OUTPUT_HIGH_Z

+

Sets the output-off mode to open the output relay when the output is turned off.

+
+

Also see

+

Output-off states

+

smua.source.offfunc

+

smua.source.offlimitY

+

smua.source.output

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92539.htm b/WebHelpDocs/2601B-PULSE/92539.htm new file mode 100644 index 0000000..e0672d6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92539.htm @@ -0,0 +1,99 @@ + + + + + smua.pulser.protect.sourcev + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.pulser.protect.sourcev

+

This attribute sets an absolute voltage protection level used to monitor the force terminals when the pulser is enabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

40 V

+
+

Usage

+

level = smua.pulser.protect.sourcev

+

smua.pulser.protect.sourcev = level

+

+ + + + + + +

level

+

The absolute voltage protection level when the pulser is enabled; 2 V to 40 V

+
+

Details

+

If the voltage on the force terminals goes above the protection level, the 2601B-PULSE automatically turns off the output.

+

The absolute voltage protection level ignores normal transients during the pulse rise and fall time.

+

The current pulse terminates within 3 µs after the remotely sensed voltage from the device under test (DUT) exceeds the specified level.

+

VARIABLE - CAUTION
Setting the protection level does not guarantee that the output will not go above the protection level. The 2601B-PULSE turns off the output as quickly as possible, but the voltage level can briefly exceed this level, potentially causing damage to the device under test (DUT).

+

The settings for this attribute are ignored if the pulser is disabled.

+

Example

+

+ + + + + + + + +

smua.pulser.protect.sourcev = 8

+

Set the voltage protection limit to 8 V.

+
+

Also see

+

smua.pulser.protect.sensev

+

smua.pulser.protect.tripped

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92540.htm b/WebHelpDocs/2601B-PULSE/92540.htm new file mode 100644 index 0000000..a0c124d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92540.htm @@ -0,0 +1,99 @@ + + + + + smua.trigger.endpulse.action + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.trigger.endpulse.action

+

This attribute enables or disables pulse sweeps when the pulser is disabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Not saved

+

1 (smua.SOURCE_HOLD)

+
+

Usage

+

pulseAction = smua.trigger.endpulse.action

+

smua.trigger.endpulse.action = pulseAction

+

+ + + + + + +

pulseAction

+

The pulse mode setting; set to one of the following values (see Details for definition):

+
  • 0 or smua.SOURCE_IDLE
  • 1 or smua.SOURCE_HOLD
+

Details

+

When set to smua.SOURCE_HOLD, this attribute disables pulse mode sweeps, holding the source level for the remainder of the step.

+

When set to smua.SOURCE_IDLE, this attribute enables pulse mode sweeps, setting the source level to the programmed (idle) level at the end of the pulse.

+

You cannot use this attribute and smua.trigger.source.pulsewidth in the same trigger model.

+

When the pulser is enabled, this setting is ignored. The source level is set to the programmed idle level at the end of the pulse.

+

Example

+

+ + + + + + + + +

smua.trigger.endpulse.action = smua.SOURCE_IDLE

+

smua.trigger.endpulse.stimulus = trigger.timer[1].EVENT_ID

+

Configure the end pulse action to achieve a pulse and configure trigger timer 1 to control the end of pulse.

+
+

Also see

+

smua.trigger.source.pulsewidth

+

Triggering

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92659.htm b/WebHelpDocs/2601B-PULSE/92659.htm new file mode 100644 index 0000000..4987dd7 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92659.htm @@ -0,0 +1,280 @@ + + + + + display.sendkey() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.sendkey()

+

This function sends a code that simulates the action of a front-panel control.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

display.sendkey(keyCode)

+

+ + + + + + +

keyCode

+

A parameter that specifies the key press to simulate; see Details for more information

+
+

Details

+

This command simulates pressing a front-panel key or navigation wheel, or turning the navigation wheel one click to the left or right.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Key codes

+

Value

+

Key list

+

 

+

Value

+

Key list

+

65

+

display.KEY_RANGEUP

+

 

+

85

+

display.KEY_RECALL

+

68

+

display.KEY_MENU

+

 

+

86

+

display.KEY_MEASA

+

69

+

display.KEY_MODEA

+

 

+

87

+

display.KEY_DIGITSA

+

70

+

display.KEY_RELA

+

 

+

88

+

display.KEY_OUTPUTA

+

71

+

display.KEY_RUN

+

 

+

92

+

display.KEY_TRIG

+

72

+

display.KEY_DISPLAY

+

 

+

93

+

display.KEY_LIMITA

+

73

+

display.KEY_AUTO

+

 

+

94

+

display.KEY_SPEEDA

+

75

+

display.KEY_EXIT

+

 

+

95

+

display.KEY_LOAD

+

77

+

display.KEY_FILTERA

+

 

+

97

+

display.WHEEL_ENTER

+

78

+

display.KEY_STORE

+

 

+

103

+

display.KEY_RIGHT

+

79

+

display.KEY_SRCA

+

 

+

104

+

display.KEY_LEFT

+

80

+

display.KEY_CONFIG

+

 

+

107

+

display.WHEEL_LEFT

+

81

+

display.KEY_RANGEDOWN

+

 

+

114

+

display.WHEEL_RIGHT

+

82

+

display.KEY_ENTER

+

 

+

 

+

 

+
+

VARIABLE - NOTE
When using this function, send built-in constants, such as display.KEY_RIGHT, rather than the numeric value, such as 103. This allows for better forward compatibility with firmware revisions.

+

Example

+

+ + + + + + +

display.sendkey(display.KEY_RUN)

+

Simulates pressing the RUN key.

+
+

Also see

+

Front panel

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92660.htm b/WebHelpDocs/2601B-PULSE/92660.htm new file mode 100644 index 0000000..c845152 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92660.htm @@ -0,0 +1,287 @@ + + + + + display.getlastkey() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.getlastkey()

+

This function retrieves the key code for the last pressed key.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

keyCode = display.getlastkey()

+

+ + + + + + +

keyCode

+

A returned value that represents the last front-panel key pressed; see Details for more information

+
+

Details

+

A history of the key code for the last pressed front-panel key is maintained by the instrument. When the instrument is turned on, or when it is transitioning from local to remote operation, the key code is set to 0 (display.KEY_NONE).

+

Pressing the EXIT (LOCAL) key normally aborts a script. To use this function with the EXIT (LOCAL) key, you must set display.locallockout to display.LOCK.

+

The table below lists the keyCode value for each front-panel action.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Key codes

+

Value

+

Key list

+

 

+

Value

+

Key list

+

0

+

display.KEY_NONE

+

 

+

82

+

display.KEY_ENTER

+

65

+

display.KEY_RANGEUP

+

 

+

85

+

display.KEY_RECALL

+

68

+

display.KEY_MENU

+

 

+

86

+

display.KEY_MEASA

+

69

+

display.KEY_MODEA

+

 

+

87

+

display.KEY_DIGITSA

+

70

+

display.KEY_RELA

+

 

+

92

+

display.KEY_TRIG

+

71

+

display.KEY_RUN

+

 

+

93

+

display.KEY_LIMITA

+

72

+

display.KEY_DISPLAY

+

 

+

94

+

display.KEY_SPEEDA

+

73

+

display.KEY_AUTO

+

 

+

95

+

display.KEY_LOAD

+

75

+

display.KEY_EXIT

+

 

+

97

+

display.WHEEL_ENTER

+

77

+

display.KEY_FILTERA

+

 

+

103

+

display.KEY_RIGHT

+

78

+

display.KEY_STORE

+

 

+

104

+

display.KEY_LEFT

+

79

+

display.KEY_SRCA

+

 

+

107

+

display.WHEEL_LEFT

+

80

+

display.KEY_CONFIG

+

 

+

114

+

display.WHEEL_RIGHT

+

81

+

display.KEY_RANGEDOWN

+

 

+

 

+

 

+
+

VARIABLE - NOTE
When using this function, use built-in constants such as display.KEY_RIGHT (rather than the numeric value of 103). This will allow for better forward compatibility with firmware revisions.

+

You cannot use this function to track the OUTPUT ON/OFF control.

+

Example

+

+ + + + + + +

key = display.getlastkey()

+

print(key)

+

On the front panel, press the MENU key and then send the code shown here. This retrieves the key code for the last pressed key.

+

Output:

+

6.80000e+01

+
+

Also see

+

display.locallockout

+

display.sendkey()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92661.htm b/WebHelpDocs/2601B-PULSE/92661.htm new file mode 100644 index 0000000..2660a33 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92661.htm @@ -0,0 +1,292 @@ + + + + + display.waitkey() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

display.waitkey()

+

This function captures the key code value for the next front-panel action.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

keyCode = display.waitkey()

+

+ + + + + + +

keyCode

+

See Details for more information

+
+

Details

+

After you send this function, script execution pauses until a front-panel action (for example, pressing a key or the navigation wheel navigation wheel, or turning the navigation wheel navigation wheel). After the action, the value of the key (or action) is returned.

+

If the EXIT (LOCAL) key is pressed while this function is waiting for a front-panel action, the script is not aborted.

+

A typical use for this function is to prompt the user to press the EXIT (LOCAL) key to abort the script or press any other key to continue. For example, if the keyCode value 75 is returned (the EXIT (LOCAL) key was pressed), you can call the exit() function to abort the script.

+

The table below lists the keyCode values for each front panel action.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Key codes

+

Value

+

Key list

+

 

+

Value

+

Key list

+

65

+

display.KEY_RANGEUP

+

 

+

85

+

display.KEY_RECALL

+

68

+

display.KEY_MENU

+

 

+

86

+

display.KEY_MEASA

+

69

+

display.KEY_MODEA

+

 

+

87

+

display.KEY_DIGITSA

+

70

+

display.KEY_RELA

+

 

+

88

+

display.KEY_OUTPUTA

+

71

+

display.KEY_RUN

+

 

+

92

+

display.KEY_TRIG

+

72

+

display.KEY_DISPLAY

+

 

+

93

+

display.KEY_LIMITA

+

73

+

display.KEY_AUTO

+

 

+

94

+

display.KEY_SPEEDA

+

75

+

display.KEY_EXIT

+

 

+

95

+

display.KEY_LOAD

+

77

+

display.KEY_FILTERA

+

 

+

97

+

display.WHEEL_ENTER

+

78

+

display.KEY_STORE

+

 

+

103

+

display.KEY_RIGHT

+

79

+

display.KEY_SRCA

+

 

+

104

+

display.KEY_LEFT

+

80

+

display.KEY_CONFIG

+

 

+

107

+

display.WHEEL_LEFT

+

81

+

display.KEY_RANGEDOWN

+

 

+

114

+

display.WHEEL_RIGHT

+

82

+

display.KEY_ENTER

+

 

+

 

+

 

+
+

VARIABLE - NOTE
When using this function, send built-in constants, such as display.KEY_RIGHT, rather than the numeric value, such as 103. This allows for better forward compatibility with firmware revisions.

+

Example

+

+ + + + + + + + +

key = display.waitkey()

+

print(key)

+

Pause script execution until the operator presses a key or the navigation wheel navigation wheel, or rotates the navigation wheel.

+

If the output is:

+

8.60000e+01

+

It indicates that the MEAS(A) key was pressed.

+
+

Also see

+

Capturing key-press codes

+

display.getlastkey()

+

display.sendkey()

+

display.settext()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92663.htm b/WebHelpDocs/2601B-PULSE/92663.htm new file mode 100644 index 0000000..7275a39 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92663.htm @@ -0,0 +1,337 @@ + + + + + status.request_enable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.request_enable

+

This attribute stores the service request (SRQ) enable register.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+
+

Usage

+

requestSRQEnableRegister = status.request_enable

+

status.request_enable = requestSRQEnableRegister

+

+ + + + + + +

requestSRQEnableRegister

+

The status of the service request (SRQ) enable register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

This attribute is used to read or write to the service request enable register. Reading the service request enable register returns a value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.MEASUREMENT_SUMMARY_BIT

+

status.MSB

+

Set summary bit indicates that an enabled event in the Measurement Event Register has occurred.

+

Bit B0 decimal value: 1

+

B1

+

status.SYSTEM_SUMMARY_BIT

+

status.SSB

+

Set summary bit indicates that an enabled event in the System Summary Register has occurred.

+

Bit B1 decimal value: 2

+

B2

+

status.ERROR_AVAILABLE

+

status.EAV

+

Set summary bit indicates that an error or status message is present in the error queue.

+

Bit B2 decimal value: 4

+

B3

+

status.QUESTIONABLE_SUMMARY_BIT

+

status.QSB

+

Set summary bit indicates that an enabled event in the Questionable Status Register has occurred.

+

Bit B3 decimal value: 8

+

B4

+

status.MESSAGE_AVAILABLE

+

status.MAV

+

Set summary bit indicates that a response message is present in the output queue.

+

Bit B4 decimal value: 16

+

B5

+

status.EVENT_SUMMARY_BIT

+

status.ESB

+

Set summary bit indicates that an enabled event in the Standard Event Status Register has occurred.

+

Bit B5 decimal value: 32

+

B6

+

Not used

+

B7

+

status.OPERATION_SUMMARY_BIT

+

status.OSB

+

Set summary bit indicates that an enabled event in the Operation Status Register has occurred.

+

Bit B7 decimal value: 128

+
+

As an example, to set bit B0 of the service request enable register, set status.request_enable = status.MSB.

+

In addition to the above values, requestSRQEnableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set requestSRQEnableRegister to the sum of their decimal values. For example, to set bits B0 and B7, set requestSRQEnableRegister to 129 (1 + 128).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

Example 1

+

+ + + + + + + + +

requestSRQEnableRegister = status.MSB + status.OSB

+

status.request_enable = requestSRQEnableRegister

+

Uses constants to set the MSB and OSB bits of the service request (SRQ) enable register.

+
+

Example 2

+

+ + + + + + + + +

-- decimal 129 = binary 10000001

+

requestSRQEnableRegister = 129

+

status.request_enable = requestSRQEnableRegister

+

Uses the decimal value to set the MSB and OSB bits of the service request (SRQ) enable register.

+
+

Also see

+

Status byte and service request (SRQ)

+

status.condition

+

status.system.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92664.htm b/WebHelpDocs/2601B-PULSE/92664.htm new file mode 100644 index 0000000..27cfaf2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92664.htm @@ -0,0 +1,325 @@ + + + + + status.request_event + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.request_event

+

This attribute stores the service request (SRQ) event register.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not saved

+

0

+
+

Usage

+

requestSRQEventRegister = status.request_event

+

+ + + + + + +

requestSRQEventRegister

+

The status of the request event register; a zero (0) indicates no bits set; other values indicate various bit settings

+
+

Details

+

This attribute is used to read the service request event register, which is returned as a numeric value. Reading this register returns a value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

The returned value can indicate one or more status events occurred.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

status.MEASUREMENT_SUMMARY_BIT

+

status.MSB

+

Set summary bit indicates that an enabled event in the Measurement Event Register has occurred.

+

Bit B0 decimal value: 1

+

B1

+

status.SYSTEM_SUMMARY_BIT

+

status.SSB

+

Set summary bit indicates that an enabled event in the System Summary Register has occurred.

+

Bit B1 decimal value: 2

+

B2

+

status.ERROR_AVAILABLE

+

status.EAV

+

Set summary bit indicates that an error or status message is present in the error queue.

+

Bit B2 decimal value: 4

+

B3

+

status.QUESTIONABLE_SUMMARY_BIT

+

status.QSB

+

Set summary bit indicates that an enabled event in the Questionable Status Register has occurred.

+

Bit B3 decimal value: 8

+

B4

+

status.MESSAGE_AVAILABLE

+

status.MAV

+

Set summary bit indicates that a response message is present in the output queue.

+

Bit B4 decimal value: 16

+

B5

+

status.EVENT_SUMMARY_BIT

+

status.ESB

+

Set summary bit indicates that an enabled event in the Standard Event Status Register has occurred.

+

Bit B5 decimal value: 32

+

B6

+

Not used

+

B7

+

status.OPERATION_SUMMARY_BIT

+

status.OSB

+

Set summary bit indicates that an enabled event in the Operation Status Register has occurred.

+

Bit B7 decimal value: 128

+
+

In addition to the above constants, requestEventRegister can be set to the decimal value of the bits set. When more than one bit of the register is set, requestEventRegister contains the sum of their decimal values. For example, if 129 is returned, bits B0 and B7 are set (1 + 128).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

Example

+

+ + + + + + + + +

requestEventRegister = status.request_event

+

print(requestEventRegister)

+

Reads the status request event register.

+

Sample output:

+

1.29000e+02

+

Converting this output (129) to its binary equivalent yields 1000 0001.

+

Therefore, this output indicates that the set bits of the status request event register are presently B0 (MSB) and B7 (OSB).

+
+

Also see

+

status.condition

+

status.system.*

+

Status byte and service request (SRQ)

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92667.htm b/WebHelpDocs/2601B-PULSE/92667.htm new file mode 100644 index 0000000..b3b70af --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92667.htm @@ -0,0 +1,91 @@ + + + + + localnode.license + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.license

+

This attribute returns the product license agreements.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

Not applicable

+
+

Usage

+

license_agreement = localnode.license

+

+ + + + + + +

license_agreement

+

The text of the license agreements

+
+

Example

+

+ + + + + + + + +

print(localnode.license)

+

Returns the license agreements for the 2601B-PULSE.

+
+

Also see

+

None

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92683.htm b/WebHelpDocs/2601B-PULSE/92683.htm new file mode 100644 index 0000000..7246a89 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92683.htm @@ -0,0 +1,521 @@ + + + + + status.questionable.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.questionable.*

+

These attributes manage the questionable status register set of the status model.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

13,056 (All bits set)

+
+

Usage

+

questionableRegister = status.questionable.condition

+

questionableRegister = status.questionable.enable

+

questionableRegister = status.questionable.event

+

questionableRegister = status.questionable.ntr

+

questionableRegister = status.questionable.ptr

+

status.questionable.enable = questionableRegister

+

status.questionable.ntr = questionableRegister

+

status.questionable.ptr = questionableRegister

+

+ + + + + + +

questionableRegister

+

The status of the questionable status register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the questionable status registers. Reading a status register returns a value. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.22880e+04 (which is 12,288) is read as the value of the condition register, the binary equivalent is 0011 0000 0000 0000. This value indicates that bits B12 and B13 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

1

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0 to B7

+

Not used

+

B8

+

status.questionable.CALIBRATION

+

status.questionable.CAL

+

An enabled bit in the questionable status calibration summary event register is set.

+

Bit B6 decimal value: 256

+

B9

+

status.questionable.UNSTABLE_OUTPUT

+

status.questionable.UO

+

An enabled bit in the questionable status unstable output summary event register is set.

+

Bit B9 decimal value: 512

+

B10

+

Not used

+

B11

+

Not used

+

B12

+

status.questionable.OVER_TEMPERATURE

+

status.questionable.OTEMP

+

An enabled bit in the questionable status over temperature summary event register is set.

+

Bit B12 decimal value: 4,096

+

B13

+

status.questionable.INSTRUMENT_SUMMARY

+

status.questionable.INST

+

An enabled bit in the questionable status instrument summary event register is set.

+

Bit B13 decimal value: 8,192

+

B14 to B15

+

Not used

+
+

As an example, to set bit B9 of the questionable status enable register, set status.questionable.enable = status.questionable.UO.

+

In addition to the above constants, questionableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set questionableRegister to the sum of their decimal values. For example, to set bits B12 and B13, set questionableRegister to 12,288 (which is the sum of 4,096 + 8,192).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

status.questionable.enable = status.questionable.OTEMP

+

Uses a constant to set the OTEMP bit of the questionable status enable register.

+
+

Example 2

+

+ + + + + + + + +

status.questionable.enable = 12288

+

Uses the decimal value to set the B12 and B13 bits of the questionable status enable register.

+
+

Also see

+

Questionable Status Registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92690.htm b/WebHelpDocs/2601B-PULSE/92690.htm new file mode 100644 index 0000000..bd75540 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92690.htm @@ -0,0 +1,528 @@ + + + + + status.measurement.instrument.smua.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.instrument.smua.*

+

This attribute contains the registers of the measurement event SMU A summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

395 (All bits set)

+
+

Usage

+

measurementRegister = status.measurement.instrument.smua.condition

+

measurementRegister = status.measurement.instrument.smua.enable

+

measurementRegister = status.measurement.instrument.smua.event

+

measurementRegister = status.measurement.instrument.smua.ntr

+

measurementRegister = status.measurement.instrument.smua.ptr

+

status.measurement.instrument.smua.enable = measurementRegister

+

status.measurement.instrument.smua.ntr = measurementRegister

+

status.measurement.instrument.smua.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the instrument measurement status SMU summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the measurement event SMU summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, assume the value 257 is returned for the enable register. The binary equivalent is 0000 0001 0000 0001. This value indicates that bit B0 (VLMT) and bit B8 (BAV) are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0*

+

status.measurement.instrument.smua.VOLTAGE_LIMIT

+

status.measurement.instrument.smua.VLMT

+

Set bit indicates that the voltage limit was exceeded.

+

Bit B0 decimal value: 1

+

B1*

+

status.measurement.instrument.smua.CURRENT_LIMIT

+

status.measurement.instrument.smua.ILMT

+

Set bit indicates that the current limit was exceeded.

+

Bit B1 decimal value: 2

+

B2

+

Not used

+

B3

+

status.measurement.instrument.smua.PROTECTION

+

status.measurement.instrument.smua.PROT

+

Set bit indicates that the pulser protection was tripped. Refer to smua.pulser.protect.tripped for events that can trip the protection circuits.

+

Bit B0 decimal value: 8

+

B4 to B6

+

Not used

+

B7

+

status.measurement.instrument.smua.READING_OVERFLOW

+

status.measurement.instrument.smua.ROF

+

Set bit indicates that an overflow reading has been detected.

+

Bit B7 decimal value: 128

+

B8

+

status.measurement.instrument.smua.BUFFER_AVAILABLE

+

status.measurement.instrument.smua.BAV

+

Set bit indicates that there is at least one reading stored in either or both dedicated reading buffers.

+

Bit B8 decimal value: 256

+

B9 to B15

+

Not used

+

* This bit is updated only when a measurement is made or smua.source.compliance is invoked.

+
+

As an example, to set bit B0 of the measurement event SMU A summary enable register, set status.measurement.instrument.smua.enable = status.measurement.instrument.smua.VLMT.

+

In addition to the above constants, measurementRegister can be set to the decimal equivalent of the bit to set. To set more than one bit of the register, set measurementRegister to the sum of their decimal weights. For example, to set bits B1 and B8, set measurementRegister to 258 (which is the sum of 2 + 256).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

status.measurement.instrument.smua.enable = status.measurement.instrument.smua.VLMT

+

Uses a constant to set the VLMT bit of the measurement event SMU A summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.measurement.instrument.smua.enable = 1

+

Uses the decimal value to set the VLMT bit of the measurement event SMU A summary enable register.

+
+

Also see

+

Measurement event registers

+

smua.pulser.protect.tripped

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92697.htm b/WebHelpDocs/2601B-PULSE/92697.htm new file mode 100644 index 0000000..d37adda --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92697.htm @@ -0,0 +1,509 @@ + + + + + status.questionable.instrument.smua.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.questionable.instrument.smua.*

+

This attribute contains the questionable status SMU A summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

+

+

+

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

4864 (All bits set)

+
+

Usage

+

questionableRegister = status.questionable.instrument.smua.condition

+

questionableRegister = status.questionable.instrument.smua.enable

+

questionableRegister = status.questionable.instrument.smua.event

+

questionableRegister = status.questionable.instrument.smua.ntr

+

questionableRegister = status.questionable.instrument.smua.ptr

+

status.questionable.instrument.smua.enable = questionableRegister

+

status.questionable.instrument.smua.ntr = questionableRegister

+

status.questionable.instrument.smua.ptr = questionableRegister

+

+ + + + + + +

questionableRegister

+

The status of the questionable status SMU summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

+

Details

+

These attributes are used to read or write to the questionable status instrument SMU summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 7.68000e+02 (which is 768) is read as the value of the condition register, the binary equivalent is 0000 0011 0000 0000. This value indicates that bit B8 and bit B9 are set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0 to B7

+

Not used

+

B8

+

status.questionable.instrument.smua.CALIBRATION

+

status.questionable.instrument.smua.CAL

+

Set bit indicates that the calibration constants stored in nonvolatile memory were corrupted and could not be loaded when the instrument powered up.

+

Bit B8 decimal value: 256

+

B9

+

status.questionable.instrument.smua.UNSTABLE_OUTPUT

+

status.questionable.instrument.smua.UO

+

Set bit indicates that an unstable output condition was detected.

+

Bit B9 decimal value: 512

+

B10 to B11

+

Not used

+

B12

+

status.questionable.instrument.smua.OVER_TEMPERATURE

+

status.questionable.instrument.smua.OTEMP

+

Set bit indicates that an over temperature condition was detected.

+

Bit B12 decimal value: 4,096

+

B13 to B15

+

Not used

+
+

As an example, to set bit B8 of the questionable status SMU A summary enable register, set status.questionable.instrument.smua.enable = status.questionable.instrument.smua.CAL.

+

In addition to the above constants, questionableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set questionableRegister to the sum of their decimal values. For example, to set bits B8 and B9, set questionableRegister to 768 (which is the sum of 256 + 512).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example

+

+ + + + + + + + +

questionableRegister = status.questionable.instrument.smua.CAL +

+

status.questionable.instrument.smua.UO

+

status.questionable.instrument.smua.enable = questionableRegister

+

Uses constants to set bits B8 and bit B9 of the questionable status SMU A summary enable register.

+
+

Example

+

+ + + + + + + + +

questionableRegister = 768

+

status.questionable.instrument.smua.enable = questionableRegister

+

Uses the decimal value to set bits B8 and bit B9 of the questionable status SMU A summary enable register.

+
+

Also see

+

Questionable Status Registers

+

status.operation.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92702.htm b/WebHelpDocs/2601B-PULSE/92702.htm new file mode 100644 index 0000000..6120402 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92702.htm @@ -0,0 +1,234 @@ + + + + + bufferVar.statuses + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

bufferVar.statuses

+

This attribute contains the status values of readings in the reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Clearing the buffer

+

See Details

+

Not applicable

+
+

Usage

+

statusInformation = bufferVar.statuses[N]

+

+ + + + + + + + + + + + + + +

statusInformation

+

The status value when reading N of the specified buffer was acquired

+

bufferVar

+

The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer

+

N

+

The reading number N; can be any value from 1 to the number of readings in the buffer; use the bufferVar.n command to determine the number of readings in the buffer

+
+

Details

+

This read-only buffer recall attribute is like an array (a Lua table) of the status values for all the readings in the buffer. The status values are floating-point numbers that encode the status value; see the following table for values.

+

For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Buffer status bits

+

Bit

+

Name

+

Hex

+

Description when bit is true

+

B0

+

Pulser

+

0x01

+

Pulser is enabled

+

B1

+

Overtemp

+

0x02

+

Overtemperature condition

+

B2

+

AutoRangeMeas

+

0x04

+

Measure range was autoranged

+

B3

+

AutoRangeSrc

+

0x08

+

Source range was autoranged

+

B4

+

4Wire

+

0x10

+

4-wire (remote) sense mode enabled

+

B5

+

Rel

+

0x20

+

Relative offset applied to reading

+

B6

+

Compliance

+

0x40

+

Source function was limited because the complementary function would be over the compliance limit

+

B7

+

Filtered

+

0x80

+

Reading was filtered

+
+

Example

+

+ + + + + + + + +

reset()

+

smua.source.func = smua.OUTPUT_DCVOLTS

+

smua.source.autorangev = smua.AUTORANGE_ON

+

smua.source.levelv = 5

+

smua.source.limiti = 10e-3

+

smua.measure.rangei = 10e-3

+

smua.source.output = smua.OUTPUT_ON

+

print(smua.measure.i(smua.nvbuffer1))

+

smua.source.output = smua.OUTPUT_OFF

+

 

+

print(smua.nvbuffer1.statuses[1])

+

Reset the instrument.

+

Set the voltage source function to DC volts. Set the range to auto.

+

Set the voltage source to 5 V.

+

Set current measure limit to 10 mA.

+

Set the current measure range to 10 mA.

+

Turn on the output.

+

Print and place the current reading in the reading buffer.

+

Turn off the output.

+

Output status value of the first measurement in the reading buffer.

+

Output example:

+

3.99470e-06

+

4.00000e+00

+
+

+

Also see

+

bufferVar.measurefunctions

+

bufferVar.measureranges

+

bufferVar.n

+

bufferVar.readings

+

bufferVar.sourcefunctions

+

bufferVar.sourceoutputstates

+

bufferVar.sourceranges

+

bufferVar.sourcevalues

+

bufferVar.timestamps

+

Reading buffers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92703.htm b/WebHelpDocs/2601B-PULSE/92703.htm new file mode 100644 index 0000000..6fec538 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92703.htm @@ -0,0 +1,92 @@ + + + + + localnode.model + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

localnode.model

+

This attribute stores the model number.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

Not applicable

+

Not applicable

+
+

Usage

+

model = localnode.model

+

+ + + + + + +

model

+

The model number of the instrument

+
+

Example

+

+ + + + + + + + +

print(localnode.model)

+

Outputs the model number of the local node. For example:

+

2601B-PULSE

+
+

Also see

+

localnode.serialno

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92706.htm b/WebHelpDocs/2601B-PULSE/92706.htm new file mode 100644 index 0000000..a2d479c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92706.htm @@ -0,0 +1,110 @@ + + + + + smua.nvbufferY + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.nvbufferY

+

This attribute contains a dedicated reading buffer.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (R)

+

Yes

+

Not applicable

+

See Details

+

Not applicable

+
+

Usage

+

bufferVar = smua.nvbufferY

+

+ + + + + + + + + + +

bufferVar

+

The dedicated reading buffer

+

Y

+

Nonvolatile buffer (1 or 2)

+
+

Details

+

The SMU contains two dedicated reading buffers: smua.nvbuffer1 and smua.nvbuffer2.

+

All routines that return measurements can also store them in either reading buffer. Overlapped measurements are always stored in a reading buffer. Synchronous measurements return either a single-point measurement or can be stored in a reading buffer if passed to the measurement command.

+

The dedicated reading buffers can be saved to internal nonvolatile memory (to retain data between power cycles) using the smua.savebuffer() function.

+

Example

+

+ + + + + + + + +

smua.measure.overlappedv(smua.nvbuffer1)

+

Store voltage readings into dedicated reading buffer 1.

+
+

Also see

+

Configuring and running sweeps

+

Reading buffers

+

savebuffer()

+

smua.makebuffer()

+

smua.measure.overlappedY()

+

smua.savebuffer()

+

smua.trigger.measure.action

+

smua.trigger.measure.set()

+

smua.trigger.measure.stimulus

+

smua.trigger.measure.Y()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92710.htm b/WebHelpDocs/2601B-PULSE/92710.htm new file mode 100644 index 0000000..d81b2e9 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92710.htm @@ -0,0 +1,60 @@ + + + + + Calibration + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Calibration

+

smua.cal.adjustdate

+

smua.cal.date

+

smua.cal.due

+

smua.cal.lock()

+

smua.cal.password

+

smua.cal.polarity

+

smua.cal.restore()

+

smua.cal.save()

+

smua.cal.state

+

smua.cal.unlock()

+

smua.contact.calibratehi()

+

smua.contact.calibratelo()

+

smua.measure.calibrateY()

+

smua.pulser.measure.calibrateY()

+

smua.pulser.source.calibratebiasi()

+

smua.pulser.source.calibratei()

+

smua.source.calibrateY()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92712.htm b/WebHelpDocs/2601B-PULSE/92712.htm new file mode 100644 index 0000000..ac1b682 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92712.htm @@ -0,0 +1,112 @@ + + + + + smua.contact.r() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.contact.r()

+

This function measures aggregate contact resistance.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

rhi, rlo = smua.contact.r()

+

+ + + + + + + + + + +

rhi

+

The measured aggregate contact resistance on the HI/sense HI side

+

rlo

+

The measured aggregate contact resistance on the LO/sense LO side

+
+

Details

+

If you attempt to perform a contact resistance measurement when any of the following conditions exist, an error is generated.

+
  • When the output is on and SMU is a current source with current range set to less than 1 mA
  • When the output is on and SMU is a voltage source with current limit set to less than 1 mA
  • When the output is off and the output off mode is High-Z
  • When the output is off and the output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCVOLTS and the off current limit set to less than 1 mA
  • When the output is off and the output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCAMPS and the source range is less than 1 mA
  • When the pulser is enabled (smua.pulser.enable attribute is set to smua.ENABLE)

VARIABLE - NOTE
Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser.

+

Example

+

+ + + + + + + + +

if not smua.contact.check() then

+

smua.contact.speed = smua.CONTACT_SLOW

+

rhi, rlo = smua.contact.r()

+

print(rhi, rlo)

+

exit()

+

end

+

Check contacts against threshold.

+

Set speed to slow.

+

Get resistance readings.

+

Output contact resistances.

+

Terminate execution.

+
+

Also see

+

Contact check connections

+

Contact check measurements

+

smua.contact.check()

+

smua.contact.speed

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92713.htm b/WebHelpDocs/2601B-PULSE/92713.htm new file mode 100644 index 0000000..4805abc --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92713.htm @@ -0,0 +1,94 @@ + + + + + smua.interlock.enable + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.interlock.enable

+

This attribute enables or disables use of the interlock signal.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Not applicable

+

Nonvolatile memory

+

smua.DISABLE

+
+

Usage

+

interlockState = smua.interlock.enable

+

smua.interlock.enable = interlockState

+

+ + + + + + +

interlockState

+

Enable or disable use of the interlock signal:

+
  • Turn the output off if the interlock signal is not asserted: smua.ENABLE
  • Ignore the interlock signal: smua.DISABLE
+

Details

+

The setting of this attribute must match the jumper setting on the 2601B-P-INT Interlock and Cable Connector Box.

+

Example

+

+ + + + + + + + +

smua.interlock.enable = smua.ENABLE

+

Enable the interlock.

+
+

Also see

+

Using the interlock

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92715.htm b/WebHelpDocs/2601B-PULSE/92715.htm new file mode 100644 index 0000000..a8bc192 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92715.htm @@ -0,0 +1,101 @@ + + + + + smua.source.offfunc + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.source.offfunc

+

This attribute sets the source function that is used (source 0 A or 0 V) when the output is turned off and the source-measure unit (SMU) is in normal output-off mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

1 (smua.OUTPUT_DCVOLTS)

+
+

Usage

+

offfunc = smua.source.offfunc

+

smua.source.offfunc = offfunc

+

+ + + + + + +

offfunc

+

Set to the source function to be used when the output is off and the SMU is in normal output-off mode. Set to one of the following values:

+
  • 0 or smua.OUTPUT_DCAMPS: Source 0 A
  • 1 or smua.OUTPUT_DCVOLTS: Source 0 V
+

Details

+

This attribute controls the source function used when the output is turned off and smua.source.offmode is set to smua.OUTPUT_NORMAL.

+

Set this attribute to smua.OUTPUT_DCVOLTS for the source to be a 0 V source when the output is off (smua.source.offlimiti is used).

+

Set it to smua.OUTPUT_DCAMPS for the source to be a 0 A source when the output is off (smua.source.offlimitv is used).

+

VARIABLE - NOTE
If the pulser is enabled and the output-off mode is set to normal, the smua.source.offfunc setting is ignored and the output circuit is shorted.

+

Example

+

+ + + + + + + + +

smua.source.offmode = smua.OUTPUT_NORMAL

+

smua.source.offfunc = smua.OUTPUT_DCVOLTS

+

Sets the normal output-off mode to source 0 V when the output is turned off.

+
+

Also see

+

Output-off states

+

smua.source.offlimitY

+

smua.source.offmode

+

smua.source.output

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92743.htm b/WebHelpDocs/2601B-PULSE/92743.htm new file mode 100644 index 0000000..b5e2a3e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92743.htm @@ -0,0 +1,206 @@ + + + + + status.measurement.protection.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.protection.*

+

This attribute contains the registers of the measurement event protection summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

measurementRegister = status.measurement.protection.condition

+

measurementRegister = status.measurement.protection.enable

+

measurementRegister = status.measurement.protection.event

+

measurementRegister = status.measurement.protection.ntr

+

measurementRegister = status.measurement.protection.ptr

+

status.measurement.protection.enable = measurementRegister

+

status.measurement.protection.ntr = measurementRegister

+

status.measurement.protection.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the measurement event protection summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the measurement event protection summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

B0

+

Not used

+

B1

+

status.measurement.protection.SMUA

+

Set bit indicates one of the pulser protection circuits have tripped.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

In addition to the above constants, measurementRegister can be set to the decimal value of the bit to set.

+

Example 1

+

+ + + + + + + + +

status.measurement.protection.enable = status.measurement.protection.SMUA

+

Uses the constant to set bit 1, the SMU A bit of the measurement event protection summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.measurement.protection.enable = 2

+

Uses the decimal value to set bit 1, the SMU A bit of the measurement event protection summary enable register.

+
+

Also see

+

Measurement event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92979.htm b/WebHelpDocs/2601B-PULSE/92979.htm new file mode 100644 index 0000000..a732926 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92979.htm @@ -0,0 +1,107 @@ + + + + + smua.measure.filter.type + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.filter.type

+

This command sets the type of filter used for measurements when the measurement filter is enabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

1 (smua.FILTER_REPEAT_AVG)

+
+

Usage

+

filterType = smua.measure.filter.type

+

smua.measure.filter.type = filterType

+

+ + + + + + +

filterType

+

The filter type to use when filtering is enabled. Set to one of the following values:

+
  • 0 or smua.FILTER_MOVING_AVG: Selects the moving filter
  • 1 or smua.FILTER_REPEAT_AVG: Selects the repeat filter
  • 2 or smua.FILTER_MEDIAN: Selects the median filter
+

Details

+

The 2601B-PULSE provides a moving average, repeating average, and median filter type.

+

For the repeating filter, the stack (filter count) is filled, and the conversions are averaged to yield a reading. The stack is then cleared, and the process starts over.

+

The moving average filter uses a first-in, first-out stack. When the stack (filter count) becomes full, the measurement conversions are averaged, yielding a reading. For each subsequent conversion placed into the stack, the oldest conversion is discarded. The stack is re-averaged, yielding a new reading.

+

The median filter uses a first-in, first-out stack. When the stack (filter count) becomes full, the reading nearest to the middle is returned. For each subsequent conversion placed into the stack, the oldest reading is discarded. The stack is then re-sorted, yielding a new reading. If the filter count is an even number, the reading returned is the average of the two middle readings.

+

VARIABLE - NOTE
If the pulser is enabled, the repeating filter is the only available filter.

+

Example

+

+ + + + + + + + +

smua.measure.filter.count = 10

+

smua.measure.filter.type = smua.FILTER_MOVING_AVG

+

smua.measure.filter.enable = smua.FILTER_ON

+

Sets the filter count to 10.

+

Sets the filter type to moving average.

+

Enables the filter.

+
+

Also see

+

Filters

+

reset()

+

setup.recall()

+

smua.measure.filter.count

+

smua.measure.filter.enable

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92990.htm b/WebHelpDocs/2601B-PULSE/92990.htm new file mode 100644 index 0000000..85d9d88 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92990.htm @@ -0,0 +1,101 @@ + + + + + smua.measure.interval + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.interval

+

This attribute sets the interval between multiple measurements.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

0 (0 s)

+
+

Usage

+

interval = smua.measure.interval

+

smua.measure.interval = interval

+

+ + + + + + +

interval

+

The interval value (in seconds); set to a value between 0 and 1

+
+

+

Details

+

This attribute sets the time interval between measurements when smua.measure.count is set to a value greater than 1.

+

The SMU attempts to start each measurement when scheduled. When the pulser is disabled, if the SMU cannot keep up with the interval setting, measurements are made as quickly as possible. When the pulser is enabled and the trigger model is not configured for asynchronous measurements, if the SMU cannot keep up with the interval setting, it aborts the sweep and turns the output off.

+

If filtered measurements are being made, the time interval is from the start of the first measurement for the filtered reading to the first measurement for a subsequent filtered reading. Extra measurements made to satisfy a filtered reading are not paced by this interval.

+

When the measure count is greater than 1 and the pulser is enabled, this must be less than 65 ms.

+

Example

+

+ + + + + + + + +

smua.measure.interval = 0.5

+

Sets the measure interval to 0.5 s.

+
+

Also see

+

reset()

+

setup.recall()

+

smua.measure.count

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92991.htm b/WebHelpDocs/2601B-PULSE/92991.htm new file mode 100644 index 0000000..ad2047e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92991.htm @@ -0,0 +1,100 @@ + + + + + smua.measure.count + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.count

+

This attribute sets the number of measurements made when a measurement is requested.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

1

+
+

Usage

+

count = smua.measure.count

+

smua.measure.count = count

+

+ + + + + + +

count

+

Number of measurements

+
+

Details

+

This attribute controls the number of measurements made any time a measurement is requested. When using a reading buffer with a measure command, this attribute also controls the number of readings to be stored.

+

If the count is set to a value greater than 1, any measurement delay set by smua.measure.delay only occurs before the first measurement, while the smua.measure.interval controls the interval between successive measurements.

+

When the pulser is enabled and measurements are not overlapped, this attribute must be less than 3500.

+

Example

+

+ + + + + + +

smua.measure.count = 10

+

Sets the measure count to 10.

+
+

Also see

+

reset()

+

setup.recall()

+

smua.measure.delay

+

smua.measure.interval

+

smua.measure.overlappedY()

+

smua.measure.Y()

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92998.htm b/WebHelpDocs/2601B-PULSE/92998.htm new file mode 100644 index 0000000..d0d1ca6 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92998.htm @@ -0,0 +1,196 @@ + + + + + status.questionable.unstable_output.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.questionable.unstable_output.*

+

This attribute contains the questionable status unstable output summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

+

Usage

+

questionableRegister = status.questionable.unstable_output.condition

+

questionableRegister = status.questionable.unstable_output.enable

+

questionableRegister = status.questionable.unstable_output.event

+

questionableRegister = status.questionable.unstable_output.ntr

+

questionableRegister = status.questionable.unstable_output.ptr

+

status.questionable.unstable_output.enable = questionableRegister

+

status.questionable.unstable_output.ntr = questionableRegister

+

status.questionable.unstable_output.ptr = questionableRegister

+

+ + + + + + +

questionableRegister

+

The status of the questionable status unstable output summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only other valid value is 2

+
+

Details

+

These attributes are used to read or write to the questionable status unstable output summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.questionable.unstable_output.SMUA

+

Set bit indicates that an unstable output condition was detected on SMU A.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the questionable status unstable output summary enable register, set status.questionable.instrument.enable = status.questionable.instrument.SMUA.

+

In addition to the above constant, questionableRegister can be set to the decimal value of the bit to set.

+

Example

+

+ + + + + + + + +

status.questionable.unstable_output.enable = status.questionable.unstable_output.SMUA

+

Uses the constant to set the SMU A bit in the questionable status unstable output summary enable register bit.

+
+

Also see

+

Questionable Status Registers

+

status.questionable.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/92999.htm b/WebHelpDocs/2601B-PULSE/92999.htm new file mode 100644 index 0000000..2d5a424 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/92999.htm @@ -0,0 +1,194 @@ + + + + + status.questionable.over_temperature.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.questionable.over_temperature.*

+

This attribute contains the questionable status over temperature summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

questionableRegister = status.questionable.over_temperature.condition

+

questionableRegister = status.questionable.over_temperature.enable

+

questionableRegister = status.questionable.over_temperature.event

+

questionableRegister = status.questionable.over_temperature.ntr

+

questionableRegister = status.questionable.over_temperature.ptr

+

status.questionable.over_temperature.enable = questionableRegister

+

status.questionable.over_temperature.ntr = questionableRegister

+

status.questionable.over_temperature.ptr = questionableRegister

+

+ + + + + + +

questionableRegister

+

The status of the questionable status over temperature summary register; a zero (0) indicates no bits set (also send 0 to clear all bits)

+
+

Details

+

These attributes are used to read or write to the questionable status over temperature summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates if a register bit is set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value

+

B0

+

Not used

+

B1

+

status.questionable.over_temperature.SMUA

+

Set bit indicates that an over temperature condition was detected on SMU A.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the questionable status over temperature summary enable register, set status.questionable.instrument.enable = status.questionable.instrument.SMUA. You can also set the bit to its decimal value.

+

Example

+

+ + + + + + + + +

status.questionable.over_temperature.enable = status.questionable.over_temperature.SMUA

+

Uses the constant to set the SMU A over temperature summary enable bit of the questionable status register.

+
+

Also see

+

Questionable Status Registers

+

status.questionable.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93000.htm b/WebHelpDocs/2601B-PULSE/93000.htm new file mode 100644 index 0000000..5993259 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93000.htm @@ -0,0 +1,195 @@ + + + + + status.questionable.instrument.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.questionable.instrument.*

+

This attribute contains the questionable status instrument summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

questionableRegister = status.questionable.instrument.condition

+

questionableRegister = status.questionable.instrument.enable

+

questionableRegister = status.questionable.instrument.event

+

questionableRegister = status.questionable.instrument.ntr

+

questionableRegister = status.questionable.instrument.ptr

+

status.questionable.instrument.enable = questionableRegister

+

status.questionable.instrument.ntr = questionableRegister

+

status.questionable.instrument.ptr = questionableRegister

+

+ + + + + + +

questionableRegister

+

The status of the questionable status instrument summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only other valid setting is 2

+
+

Details

+

These attributes are used to read or write to the questionable status instrument summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bit is set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.questionable.instrument.SMUA

+

Set bit indicates one or more enabled bits for the SMU A questionable register are set.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the questionable status instrument summary enable register, set status.questionable.instrument.enable = status.questionable.instrument.SMUA.

+

In addition to the constant, questionableRegister can be set to the decimal value of the bit.

+

Example

+

+ + + + + + + + +

status.questionable.instrument.enable = status.questionable.instrument.SMUA

+

Uses a constant to set the SMUA bit of the questionable status instrument summary enable register.

+
+

Also see

+

Questionable Status Registers

+

status.questionable.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93010.htm b/WebHelpDocs/2601B-PULSE/93010.htm new file mode 100644 index 0000000..1cdee98 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93010.htm @@ -0,0 +1,206 @@ + + + + + status.measurement.reading_overflow.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.reading_overflow.*

+

This attribute contains the measurement event reading overflow summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

measurementRegister = status.measurement.reading_overflow.condition

+

measurementRegister = status.measurement.reading_overflow.enable

+

measurementRegister = status.measurement.reading_overflow.event

+

measurementRegister = status.measurement.reading_overflow.ntr

+

measurementRegister = status.measurement.reading_overflow.ptr

+

status.measurement.reading_overflow.enable = measurementRegister

+

status.measurement.reading_overflow.ntr = measurementRegister

+

status.measurement.reading_overflow.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the measurement reading overflow summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the measurement event reading overflow summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, assume the value 2 is returned for the enable register. The binary equivalent is 0000 0000 0000 0010. This value indicates that bit B1 (SMUA) is set.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.measurement.reading_overflow.SMUA

+

Set bit indicates that an overflow reading has been detected for SMU A.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

In addition to the above constants, measurementRegister can be set to the decimal value of the bit to set.

+

Example 1

+

+ + + + + + + + +

status.measurement.reading_overflow.enable = status.measurement.reading_overflow.SMUA

+

Uses the constant to set bit B1 of the measurement reading overflow summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.measurement.reading_overflow.enable = 2

+

Uses the decimal value to set bit B1 of the measurement reading overflow summary enable register.

+
+

Also see

+

Measurement event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93012.htm b/WebHelpDocs/2601B-PULSE/93012.htm new file mode 100644 index 0000000..630fb7b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93012.htm @@ -0,0 +1,206 @@ + + + + + status.measurement.voltage_limit.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.voltage_limit.*

+

This attribute contains the measurement event voltage limit summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

measurementRegister = status.measurement.voltage_limit.condition

+

measurementRegister = status.measurement.voltage_limit.enable

+

measurementRegister = status.measurement.voltage_limit.event

+

measurementRegister = status.measurement.voltage_limit.ntr

+

measurementRegister = status.measurement.voltage_limit.ptr

+

status.measurement.voltage_limit.enable = measurementRegister

+

status.measurement.voltage_limit.ntr = measurementRegister

+

status.measurement.voltage_limit.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the measurement voltage limit summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other decimal values indicate various bit settings

+
+

Details

+

These attributes read or write to the measurement event voltage limit summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.measurement.voltage_limit.SMUA

+

Set bit indicates the enabled VLMT bit for the SMU A measurement register is set.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

In addition to the above constants, measurementRegister can be set to the decimal value of the bit to set.

+

Example 1

+

+ + + + + + + + +

status.measurement.voltage_limit.enable = status.measurement.voltage_limit.SMUA

+

Uses the constant to set the SMUA bit, B1, of the measurement event voltage limit summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.measurement.voltage_limit.enable = 2

+

Uses the decimal value to set the SMUA bit, B1, of the measurement event voltage limit summary enable register.

+
+

Also see

+

Measurement event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93014.htm b/WebHelpDocs/2601B-PULSE/93014.htm new file mode 100644 index 0000000..8db4e54 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93014.htm @@ -0,0 +1,206 @@ + + + + + status.operation.calibrating.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.calibrating.*

+

This attribute contains the operation status calibration summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

operationRegister = status.operation.calibrating.condition

+

operationRegister = status.operation.calibrating.enable

+

operationRegister = status.operation.calibrating.event

+

operationRegister = status.operation.calibrating.ntr

+

operationRegister = status.operation.calibrating.ptr

+

status.operation.calibrating.enable = operationRegister

+

status.operation.calibrating.ntr = operationRegister

+

status.operation.calibrating.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation calibrating event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status calibration summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.operation.calibrating.SMUA

+

Set bit indicates that SMU A is unlocked for calibration.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

Example 1

+

+ + + + + + + + +

status.operation.calibrating.enable = status.operation.calibrating.SMUA

+

Sets the SMUA bit, B1, of the operation status calibration summary enable register using a constant.

+
+

Example 2

+

+ + + + + + + + +

status.operation.calibrating.enable = 2

+

Sets the SMUA bit, B1, of the operation status calibration summary enable register using a decimal value.

+
+

Also see

+

Operation Status Registers

+

status.operation.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93016.htm b/WebHelpDocs/2601B-PULSE/93016.htm new file mode 100644 index 0000000..16eb66e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93016.htm @@ -0,0 +1,538 @@ + + + + + status.operation.instrument.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.instrument.*

+

This attribute contains the operation status instrument summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

31,746 (All bits set)

+
+

Usage

+

operationRegister = status.operation.instrument.condition

+

operationRegister = status.operation.instrument.enable

+

operationRegister = status.operation.instrument.event

+

operationRegister = status.operation.instrument.ntr

+

operationRegister = status.operation.instrument.ptr

+

status.operation.instrument.enable = operationRegister

+

status.operation.instrument.ntr = operationRegister

+

status.operation.instrument.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status instrument summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1,026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.operation.instrument.SMUA

+

Set bit indicates one or more enabled bits for the operation status SMU A summary register is set.

+

Bit B1 decimal value: 2

+

B2 to B9

+

Not used

+

B10

+

status.operation.instrument.TRIGGER_BLENDER

+

status.operation.instrument.TRGBLND

+

Set bit indicates one or more enabled bits for the operation status trigger blender summary register is set.

+

Bit B10 decimal value: 1,024.

+

B11

+

status.operation.instrument.TRIGGER_TIMER

+

status.operation.instrument.TRGTMR

+

Set bit indicates one or more enabled bits for the operation status trigger timer summary register is set.

+

Bit B11 decimal value: 2,048

+

B12

+

status.operation.instrument.DIGITAL_IO

+

status.operation.instrument.DIGIO

+

Set bit indicates one or more enabled bits for the operation status digital I/O summary register is set.

+

Bit B12 decimal value: 4,096

+

B13

+

status.operation.instrument.TSPLINK

+

Set bit indicates one or more enabled bits for the operation status TSP-Link summary register is set.

+

Bit B13 decimal value: 8,192

+

B14

+

status.operation.instrument.LAN

+

Set bit indicates one or more enabled bits for the operation status LAN summary register is set.

+

Bit B14 decimal value: 16,384

+

B15

+

Not used

+
+

As an example, to set bit B1 of the operation status instrument summary enable register, set status.operation.instrument.enable = status.operation.instrument.SMUA.

+

In addition to the above constants, operationRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1,024).

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

operationRegister = status.operation.instrument.SMUA +

+

status.operation.instrument.TRGBLND

+

status.operation.instrument.enable = operationRegister

+

Use constants to set bit B1 and bit B10 of the operation status instrument summary enable register.

+
+

Example 2

+

+ + + + + + + + +

-- 1026 = binary 0000 0100 0000 0010

+

operationRegister = 1026

+

status.operation.instrument.enable = operationRegister

+

Uses a decimal value to set bit B1 and bit B10 of the operation status instrument summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.*

+

Condition register sets of:

+

status.operation.instrument.digio.*

+

status.operation.instrument.lan.*

+

status.operation.instrument.trigger_blender.*

+

status.operation.instrument.trigger_timer.*

+

status.operation.instrument.tsplink.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93017.htm b/WebHelpDocs/2601B-PULSE/93017.htm new file mode 100644 index 0000000..bf61694 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93017.htm @@ -0,0 +1,207 @@ + + + + + status.operation.measuring.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.measuring.*

+

This attribute contains the operation status measuring summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

operationRegister = status.operation.measuring.condition

+

operationRegister = status.operation.measuring.enable

+

operationRegister = status.operation.measuring.event

+

operationRegister = status.operation.measuring.ntr

+

operationRegister = status.operation.measuring.ptr

+

status.operation.measuring.enable = operationRegister

+

status.operation.measuring.ntr = operationRegister

+

status.operation.measuring.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status measuring summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only other valid value is 2

+
+

Details

+

These attributes are used to read or write to the operation status measuring summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.operation.measuring.SMUA

+

Bit is set when SMU A is taking an overlapped measurement, but it is not set when taking a normal synchronous measurement.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

In addition to the above constants, operationRegister can be set to the decimal equivalent of the bit to set.

+

Example 1

+

+ + + + + + + + +

status.operation.measuring.enable = status.operation.measuring.SMUA

+

Uses the constant to set the SMUA bit, B1, of the operation status measuring summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.operation.measuring.enable = 2

+

Uses the decimal value to set the SMUA bit, B1, of the operation status measuring summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93035.htm b/WebHelpDocs/2601B-PULSE/93035.htm new file mode 100644 index 0000000..405c7bf --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93035.htm @@ -0,0 +1,195 @@ + + + + + status.questionable.calibration.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.questionable.calibration.*

+

This attribute contains the questionable status calibration summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

questionableRegister = status.questionable.calibration.condition

+

questionableRegister = status.questionable.calibration.enable

+

questionableRegister = status.questionable.calibration.event

+

questionableRegister = status.questionable.calibration.ntr

+

questionableRegister = status.questionable.calibration.ptr

+

status.questionable.calibration.enable = questionableRegister

+

status.questionable.calibration.ntr = questionableRegister

+

status.questionable.calibration.ptr = questionableRegister

+

+ + + + + + +

questionableRegister

+

The status of the questionable status calibration summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the questionable status calibration summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.questionable.calibration.SMUA

+

Set bit indicates that the SMU A calibration constants stored in nonvolatile memory were corrupted and could not be loaded when the instrument powered up.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the questionable status calibration summary enable register, set status.questionable.calibration.enable = status.questionable.calibration.SMUA.

+

In addition to the above constants, questionableRegister can be set to 2, the decimal value of the B1 bit.

+

Example

+

+ + + + + + + + +

status.questionable.calibration.enable = status.questionable.calibration.SMUA

+

Uses a constant to set the SMUA bit of the questionable status calibration summary enable register.

+
+

Also see

+

Questionable Status Registers

+

status.questionable.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93037.htm b/WebHelpDocs/2601B-PULSE/93037.htm new file mode 100644 index 0000000..ec32bc1 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93037.htm @@ -0,0 +1,534 @@ + + + + + status.operation.trigger_overrun.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.trigger_overrun.*

+

This attribute contains the operation status trigger overrun summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

31,746 (All bits set)

+
+

Usage

+

operationRegister = status.operation.trigger_overrun.condition

+

operationRegister = status.operation.trigger_overrun.enable

+

operationRegister = status.operation.trigger_overrun.event

+

operationRegister = status.operation.trigger_overrun.ntr

+

operationRegister = status.operation.trigger_overrun.ptr

+

status.operation.trigger_overrun.enable = operationRegister

+

status.operation.trigger_overrun.ntr = operationRegister

+

status.operation.trigger_overrun.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status trigger overrun summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status trigger overrun summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1,026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

**

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

>

+

*

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

0

+

1

+

0

+
+

* Least significant bit
** Most significant bit

+

The bits in this register summarize events in other registers. A set bit in this summary register indicates that an enabled event in one of the summarized registers is set.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.operation.trigger_overrun.SMUA

+

Set bit indicates one of the enabled bits in the operation status SMU A trigger overrun event register is set.

+

Bit B1 decimal value: 2

+

B2 to B9

+

Not used

+

B10

+

status.operation.trigger_overrun.TRIGGER_BLENDER

+

status.operation.trigger_overrun.TRGBLND

+

Set bit indicates one of the enabled bits in the operation status trigger blender overrun event register is set.

+

Bit B10 decimal value: 1,024

+

B11

+

status.operation.trigger_overrun.TRIGGER_TIMER

+

status.operation.trigger_overrun.TRGTMR

+

Set bit indicates one of the enabled bits in the operation status trigger timer overrun event register is set.

+

Bit B11 decimal value: 2,048

+

B12

+

status.operation.trigger_overrun.DIGITAL_IO

+

status.operation.trigger_overrun.DIGIO

+

Set bit indicates one of the enabled bits in the operation status digital I/O overrun event register is set.

+

Bit B12 decimal value: 4,096

+

B13

+

status.operation.trigger_overrun.TSPLINK

+

Set bit indicates one of the enabled bits in the operation status TSP-Link overrun event register is set.

+

Bit B13 decimal value: 8,192

+

B14

+

status.operation.trigger_overrun.LAN

+

Set bit indicates one of the enabled bits in the operation status LAN trigger overrun event register is set.

+

Bit B14 decimal value: 16,384

+

B15

+

Not used

+
+

As an example, to set bit B1 of the operation status trigger overrun summary enable register, set status.operation.trigger_overrun.enable = status.operation.trigger_overrun.SMUA.

+

In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1,024).

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B7

+

B6

+

B5

+

B4

+

B3

+

B2

+

B1

+

B0

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

128

+

64

+

32

+

16

+

8

+

4

+

2

+

1

+

Weights

+

(27)

+

(26)

+

(25)

+

(24)

+

(23)

+

(22)

+

(21)

+

(20)

+
+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Bit

+

B15

+

B14

+

B13

+

B12

+

B11

+

B10

+

B9

+

B8

+

Binary value

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

0/1

+

Decimal

+

32,768

+

16,384

+

8,192

+

4,096

+

2,048

+

1,024

+

512

+

256

+

Weights

+

(215)

+

(214)

+

(213)

+

(212)

+

(211)

+

(210)

+

(29)

+

(28)

+
+

Example 1

+

+ + + + + + + + +

operationRegister = status.operation.trigger_overrun.SMUA + status.operation.trigger_overrun.TRGBLND

+

status.operation.trigger_overrun.enable = operationRegister

+

Uses constants to set bits B1 and bit B10 of the operation status trigger overrun summary enable register.

+
+

Example 2

+

+ + + + + + + + +

operationRegister = 1026

+

status.operation.trigger_overrun.enable = operationRegister

+

Uses the decimal value to set bits B1 and bit B10 of the operation status trigger overrun summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93038.htm b/WebHelpDocs/2601B-PULSE/93038.htm new file mode 100644 index 0000000..0b8a5bf --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93038.htm @@ -0,0 +1,195 @@ + + + + + status.operation.sweeping.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.operation.sweeping.*

+

This attribute contains the operation status sweeping summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

operationRegister = status.operation.sweeping.condition

+

operationRegister = status.operation.sweeping.enable

+

operationRegister = status.operation.sweeping.event

+

operationRegister = status.operation.sweeping.ntr

+

operationRegister = status.operation.sweeping.ptr

+

status.operation.sweeping.enable = operationRegister

+

status.operation.sweeping.ntr = operationRegister

+

status.operation.sweeping.ptr = operationRegister

+

+ + + + + + +

operationRegister

+

The status of the operation status sweeping summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the operation status sweeping summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.operation.sweeping.SMUA

+

Set bit indicates that SMU A is sweeping.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the operation status sweeping summary enable register, set status.operation.sweeping.enable = status.operation.sweeping.SMUA.

+

In addition to the above constants, operationRegister can be set to 2, the decimal value of Bit 1.

+

Example

+

+ + + + + + + + +

status.operation.sweeping.enable = status.operation.sweeping.SMUA

+

Uses a constant to set the SMUA bit of the operation status sweeping summary enable register.

+
+

Also see

+

Operation Status Registers

+

status.operation.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93039.htm b/WebHelpDocs/2601B-PULSE/93039.htm new file mode 100644 index 0000000..23e7da8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93039.htm @@ -0,0 +1,207 @@ + + + + + status.measurement.instrument.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.instrument.*

+

This attribute contains the registers of the measurement event instrument summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

measurementRegister = status.measurement.instrument.condition

+

measurementRegister = status.measurement.instrument.enable

+

measurementRegister = status.measurement.instrument.event

+

measurementRegister = status.measurement.instrument.ntr

+

measurementRegister = status.measurement.instrument.ptr

+

status.measurement.instrument.enable = measurementRegister

+

status.measurement.instrument.ntr = measurementRegister

+

status.measurement.instrument.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the measurement event instrument summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the measurement event instrument summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.measurement.instrument.SMUA

+

Set bit indicates one or more enabled bits of the measurement event SMU A summary register is set.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the measurement event instrument summary enable register, set status.measurement.instrument.enable = status.measurement.instrument.SMUA.

+

In addition to the constant, measurementRegister can be set to the decimal value of bit B1.

+

Example 1

+

+ + + + + + + + +

status.measurement.instrument.enable = status.measurement.instrument.SMUA

+

Uses the constant to set the SMU A bit of the measurement event instrument summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.measurement.instrument.enable = 2

+

Uses the decimal value to set the SMU A bit of the measurement event instrument summary enable register.

+
+

Also see

+

Measurement event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93040.htm b/WebHelpDocs/2601B-PULSE/93040.htm new file mode 100644 index 0000000..74a17cd --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93040.htm @@ -0,0 +1,208 @@ + + + + + status.measurement.current_limit.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.current_limit.*

+

This attribute contains the measurement event current limit summary registers.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

measurementRegister = status.measurement.current_limit.condition

+

measurementRegister = status.measurement.current_limit.enable

+

measurementRegister = status.measurement.current_limit.event

+

measurementRegister = status.measurement.current_limit.ntr

+

measurementRegister = status.measurement.current_limit.ptr

+

status.measurement.current_limit.enable = measurementRegister

+

status.measurement.current_limit.ntr = measurementRegister

+

status.measurement.current_limit.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the measurement event current limit summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the measurement event current limit summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.measurement.current_limit.SMUA

+

Set bit indicates that the SMU A current limit was exceeded.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the measurement event current limit summary enable register, set status.measurement.current_limit.enable = status.measurement.current_limit.SMUA.

+

In addition to the above constants, measurementRegister can be set to the decimal value of Bit B1.

+

Example 1

+

+ + + + + + + + +

status.measurement.current_limit.enable = status.measurement.current_limit.SMUA

+

Sets the SMUA bit of the Measurement Event Current Limit Summary Enable Register using a constant.

+
+

Example 2

+

+ + + + + + + + +

status.measurement.current_limit.enable = 2

+

Sets the SMUA bit of the Measurement Event Current Limit Summary Enable Register using a decimal value.

+
+

Also see

+

Measurement event registers

+

status.measurement.instrument.smua.*

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93041.htm b/WebHelpDocs/2601B-PULSE/93041.htm new file mode 100644 index 0000000..006ea63 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93041.htm @@ -0,0 +1,207 @@ + + + + + status.measurement.buffer_available.* + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

status.measurement.buffer_available.*

+

This attribute contains the measurement event buffer available summary register set.

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute

+

- -

+

- -

+

- -

+

- -

+

.condition (R)

+

Yes

+

Not applicable

+

Not saved

+

Not applicable

+

.enable (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.event (R)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ntr (RW)

+

Yes

+

Status reset

+

Not saved

+

0

+

.ptr (RW)

+

Yes

+

Status reset

+

Not saved

+

2 (All bits set)

+
+

Usage

+

measurementRegister = status.measurement.buffer_available.condition

+

measurementRegister = status.measurement.buffer_available.enable

+

measurementRegister = status.measurement.buffer_available.event

+

measurementRegister = status.measurement.buffer_available.ntr

+

measurementRegister = status.measurement.buffer_available.ptr

+

status.measurement.buffer_available.enable = measurementRegister

+

status.measurement.buffer_available.ntr = measurementRegister

+

status.measurement.buffer_available.ptr = measurementRegister

+

+ + + + + + +

measurementRegister

+

The status of the measurement event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings

+
+

Details

+

These attributes are used to read or write to the measurement event buffer available summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.

+

For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.

+

+ + + + + + + + + + + + + + + + + + +

Bit

+

Value and description

+

B0

+

Not used

+

B1

+

status.measurement.buffer_available.SMUA

+

Set bit indicates that there is at least one reading stored in either or both of the dedicated reading buffers.

+

Bit B1 decimal value: 2

+

Binary value: 0000 0010

+

B2 to B15

+

Not used

+
+

As an example, to set bit B1 of the measurement event buffer available summary enable register, set status.measurement.buffer_available.enable = status.measurement.buffer_available.SMUA.

+

In addition to the above constants, measurementRegister can be set to the decimal equivalent of the bit to set.

+

Example 1

+

+ + + + + + + + +

status.measurement.buffer_available.enable = status.measurement.buffer_available.SMUA

+

Uses the constant to set the SMUA bit of the measurement event buffer available summary enable register.

+
+

Example 2

+

+ + + + + + + + +

status.measurement.buffer_available.enable = 2

+

Uses the decimal value to set the SMUA bit of the measurement event buffer available summary enable register.

+
+

Also see

+

Measurement event registers

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93042.htm b/WebHelpDocs/2601B-PULSE/93042.htm new file mode 100644 index 0000000..f81a898 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93042.htm @@ -0,0 +1,100 @@ + + + + + smua.sense + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.sense

+

This attribute contains the state of the sense mode.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

SMU reset
Instrument reset
Recall setup

+

Saved setup

+

0 (smua.SENSE_LOCAL)

+
+

Usage

+

senseMode = smua.sense

+

smua.sense = senseMode

+

+ + + + + + +

senseMode

+

The sense mode; set to one of the following:

+
  • 0 or smua.SENSE_LOCAL: Selects local sense (2-wire)
  • 1 or smua.SENSE_REMOTE: Selects remote sense (4-wire)
  • 3 or smua.SENSE_CALA: Selects calibration sense mode
+

+

Details

+

You can do source-measure operations using either 2-wire local sense connections or 4-wire remote sense connections.

+

VARIABLE - NOTE
When the pulser is enabled, the instrument always uses 4-wire remote sensing. The setting of smua.sense is ignored.

+

You can change the sense mode between local and remote while the output is on.

+

The smua.SENSE_CALA mode is only used for calibration and may only be selected when calibration is enabled. The calibration sense mode cannot be selected while the output is on.

+

Example

+

+ + + + + + + + +

smua.sense = smua.SENSE_REMOTE

+

Select 4-wire remote sensing.

+
+

Also see

+

2-wire local sensing connections

+

4-wire remote sensing connections

+

Sense mode selection

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93060.htm b/WebHelpDocs/2601B-PULSE/93060.htm new file mode 100644 index 0000000..9a9a670 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93060.htm @@ -0,0 +1,103 @@ + + + + + smua.cal.polarity + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.cal.polarity

+

This attribute controls which calibration constants are used for all subsequent measurements.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
SMU calibration lock
Recall setup

+

Not saved

+

0 (smua.CAL_AUTO)

+
+

Usage

+

calPolarity = smua.cal.polarity

+

smua.cal.polarity = calPolarity

+

+ + + + + + +

calPolarity

+

The polarity to use for measurements. Set to one of the following values:

+
  • 0 or smua.CAL_AUTO: Automatic polarity detection
  • 1 or smua.CAL_POSITIVE: Measure with positive polarity calibration constants
  • 2 or smua.CAL_NEGATIVE: Measure with negative polarity calibration constants
+

Details

+

This attribute controls which polarity calibration constants are used to make all subsequent measurements.

+

This attribute does not affect the smua.measure.calibrateY() and smua.pulser.measure.calibrateY() commands. The polarity for the measure calibrate commands is dictated by their range parameters. The measure calibration commands require the measurements provided to have been made using the polarity being calibrated.

+

When making measurements for points far away from zero, the desired polarity constants are inherently used. However, when making measurements near zero, it is possible that the instrument could use the calibration constants from the wrong polarity. Setting smua.cal.polarity to positive or negative forces measurements to be made using the calibration constants for a given polarity, rather than basing the choice on the raw measurement data.

+

This attribute can only be set to positive or negative when calibration is unlocked. This attribute is automatically set to smua.CAL_AUTO when calibration is locked.

+

Example

+

+ + + + + + + + +

smua.cal.polarity = smua.CAL_POSITIVE

+

Selects positive calibration constants for all subsequent measurements.

+
+

Also see

+

Adjustment

+

reset()

+

smua.cal.lock()

+

smua.cal.unlock()

+

smua.measure.calibrateY()

+

smua.pulser.measure.calibrateY()

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93150.htm b/WebHelpDocs/2601B-PULSE/93150.htm new file mode 100644 index 0000000..63f0663 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93150.htm @@ -0,0 +1,123 @@ + + + + + SMU + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

SMU

+

localnode.linefreq

+

smua.abort()

+

smua.buffer.getstats()

+

smua.buffer.recalculatestats()

+

smua.contact.check()

+

smua.contact.r()

+

smua.contact.speed

+

smua.contact.threshold

+

smua.makebuffer()

+

smua.measure.autorangeY

+

smua.measure.autozero

+

smua.measure.count

+

smua.measure.delay

+

smua.measure.delayfactor

+

smua.measure.filter.count

+

smua.measure.filter.enable

+

smua.measure.filter.type

+

smua.measure.highcrangedelayfactor

+

smua.measure.interval

+

smua.measure.lowrangeY

+

smua.measure.nplc

+

smua.measure.overlappedY()

+

smua.measure.rangeY

+

smua.measure.rel.enableY

+

smua.measure.rel.levelY

+

smua.measure.Y()

+

smua.measureYandstep()

+

smua.nvbufferY

+

smua.pulser.enable

+

smua.pulser.measure.aperture

+

smua.pulser.measure.delay

+

smua.pulser.protect.sensev

+

smua.pulser.protect.sourcev

+

smua.pulser.protect.tripped

+

smua.pulser.rangeY

+

smua.reset()

+

smua.savebuffer()

+

smua.sense

+

smua.source.autorangeY

+

smua.source.compliance

+

smua.source.delay

+

smua.source.func

+

smua.source.highc

+

smua.source.levelY

+

smua.source.limitY

+

smua.source.lowrangeY

+

smua.source.offlimitY

+

smua.source.offmode

+

smua.source.output

+

smua.source.rangeY

+

smua.source.settling

+

smua.trigger.arm.count

+

smua.trigger.arm.set()

+

smua.trigger.arm.stimulus

+

smua.trigger.ARMED_EVENT_ID

+

smua.trigger.autoclear

+

smua.trigger.count

+

smua.trigger.endpulse.action

+

smua.trigger.endpulse.set()

+

smua.trigger.endpulse.stimulus

+

smua.trigger.endsweep.action

+

smua.trigger.IDLE_EVENT_ID

+

smua.trigger.initiate()

+

smua.trigger.measure.action

+

smua.trigger.measure.set()

+

smua.trigger.measure.stimulus

+

smua.trigger.measure.Y()

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

smua.trigger.source.action

+

smua.trigger.source.limitY

+

smua.trigger.source.linearY()

+

smua.trigger.source.listY()

+

smua.trigger.source.logY()

+

smua.trigger.source.pulsewidth

+

smua.trigger.source.set()

+

smua.trigger.source.stimulus

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

smua.trigger.SWEEPING_EVENT_ID

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

Status model

Time

Triggering

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93152.htm b/WebHelpDocs/2601B-PULSE/93152.htm new file mode 100644 index 0000000..5de81e2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93152.htm @@ -0,0 +1,133 @@ + + + + + Triggering + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Triggering

+

Triggering allows you to capture measurements when an input signal or combination of input signals meet a set of conditions that you set. See Sweep operation for details on sweeping.

+

digio.trigger[N].assert()

+

digio.trigger[N].clear()

+

digio.trigger[N].EVENT_ID

+

digio.trigger[N].mode

+

digio.trigger[N].overrun

+

digio.trigger[N].pulsewidth

+

digio.trigger[N].release()

+

digio.trigger[N].reset()

+

digio.trigger[N].stimulus

+

digio.trigger[N].wait()

+

display.trigger.clear()

+

display.trigger.EVENT_ID

+

display.trigger.overrun

+

display.trigger.wait()

+

lan.trigger[N].assert()

+

lan.trigger[N].clear()

+

lan.trigger[N].connect()

+

lan.trigger[N].connected

+

lan.trigger[N].disconnect()

+

lan.trigger[N].EVENT_ID

+

lan.trigger[N].ipaddress

+

lan.trigger[N].mode

+

lan.trigger[N].overrun

+

lan.trigger[N].protocol

+

lan.trigger[N].pseudostate

+

lan.trigger[N].stimulus

+

lan.trigger[N].wait()

+

smua.pulser.measure.delay

+

smua.trigger.arm.count

+

smua.trigger.arm.set()

+

smua.trigger.arm.stimulus

+

smua.trigger.ARMED_EVENT_ID

+

smua.trigger.autoclear

+

smua.trigger.count

+

smua.trigger.endpulse.action

+

smua.trigger.endpulse.set()

+

smua.trigger.endpulse.stimulus

+

smua.trigger.endsweep.action

+

smua.trigger.IDLE_EVENT_ID

+

smua.trigger.initiate()

+

smua.trigger.measure.action

+

smua.trigger.measure.set()

+

smua.trigger.measure.stimulus

+

smua.trigger.measure.Y()

+

smua.trigger.MEASURE_COMPLETE_EVENT_ID

+

smua.trigger.PULSE_COMPLETE_EVENT_ID

+

smua.trigger.source.action

+

smua.trigger.source.limitY

+

smua.trigger.source.linearY()

+

smua.trigger.source.listY()

+

smua.trigger.source.logY()

+

smua.trigger.source.pulsewidth

+

smua.trigger.source.set()

+

smua.trigger.source.stimulus

+

smua.trigger.SOURCE_COMPLETE_EVENT_ID

+

smua.trigger.SWEEP_COMPLETE_EVENT_ID

+

smua.trigger.SWEEPING_EVENT_ID

+

trigger.blender[N].clear()

+

trigger.blender[N].EVENT_ID

+

trigger.blender[N].orenable

+

trigger.blender[N].overrun

+

trigger.blender[N].reset()

+

trigger.blender[N].stimulus[M]

+

trigger.blender[N].wait()

+

trigger.clear()

+

trigger.EVENT_ID

+

trigger.generator[N].assert()

+

trigger.generator[N].EVENT_ID

+

trigger.timer[N].clear()

+

trigger.timer[N].count

+

trigger.timer[N].delay

+

trigger.timer[N].delaylist

+

trigger.timer[N].EVENT_ID

+

trigger.timer[N].overrun

+

trigger.timer[N].passthrough

+

trigger.timer[N].reset()

+

trigger.timer[N].stimulus

+

trigger.timer[N].wait()

+

trigger.wait()

+

tsplink.trigger[N].assert()

+

tsplink.trigger[N].clear()

+

tsplink.trigger[N].EVENT_ID

+

tsplink.trigger[N].mode

+

tsplink.trigger[N].overrun

+

tsplink.trigger[N].pulsewidth

+

tsplink.trigger[N].release()

+

tsplink.trigger[N].reset()

+

tsplink.trigger[N].stimulus

+

tsplink.trigger[N].wait()

+ + + + +
+

See also

About TSP commands

Beeper control

Bit manipulation and logic operations

Calibration

Data queue

Digital I/O

Display

Error queue

Event log

File I/O

GPIB

Instrument identification

LAN and LXI

Miscellaneous

Parallel script execution

Queries and response messages

Reading buffer

Reset

RS-232

Saved setups

Scripting

SMU

Status model

Time

TSP-Link

TSP-Net

Userstrings

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93173.htm b/WebHelpDocs/2601B-PULSE/93173.htm new file mode 100644 index 0000000..a5687a8 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93173.htm @@ -0,0 +1,139 @@ + + + + + smua.measureYandstep() + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measureYandstep()

+

This function makes one or two measurements and then steps the source.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Function

+

Yes

+

 

+

 

+

 

+
+

Usage

+

reading = smua.measureYandstep(sourceValue)

+

iReading, vReading = smua.measureivandstep(sourceValue)

+

+ + + + + + + + + + + + + + + + + + + + + + +

reading

+

The measured reading before stepping the source

+

Y

+

SMU measurement function (v = voltage, i = current, r = resistance, p = power)

+

sourceValue

+

Source value to be set after the measurement is made

+

iReading

+

The current reading before stepping the source

+

vReading

+

The voltage reading before stepping the source

+
+

Details

+

The smua.measureYandstep() function makes a measurement and then sets the source to sourceValue. The smua.measureivandstep() function makes two measurements simultaneously, one for current (i) and one for voltage (v), and then sets the source to sourceValue.

+

Measurements are in the following units of measure: v = volts, i = amperes, r = ohms, p = watts.

+

The specified source value should be appropriate for the selected source function. For example, if the source voltage function is selected, then sourceValue is expected to be a new voltage level.

+

Both source and measure autorange must be disabled before using this function. This function cannot be used if source high capacitance mode is enabled (high capacitance mode requires autoranging to be enabled).

+

This function is provided for very fast execution of source-measure loops. The measurement is made before the source is stepped. Before using this function, and before any loop this function may be used in, set the source value to its initial level.

+

VARIABLE - NOTE
This function is not available when the pulser is enabled.

+

Example

+

+ + + + + + + + +

local ivalues = {}

+

smua.source.rangev = 1

+

smua.source.levelv = 0

+

smua.measure.rangei = 0.01

+

smua.source.output = smua.OUTPUT_ON

+

for index = 1, 10 do

+

ivalues[index] = smua.measureiandstep(index / 10)

+

end

+

ivalues[11] = smua.measure.i()

+

This use of the measure and step function measures current, starting at a source value of 0 V. After each current measurement, the source is stepped 100 mV for the next current measurement. The final source level is 1 V, where current is measured again.

+
+

+

Also see

+

smua.measure.autorangeY

+

smua.measure.Y()

+

smua.source.autorangeY

+

smua.trigger.source.limitY

+

smua.trigger.source.linearY()

+

smua.trigger.source.listY()

+

smua.trigger.source.logY()

+

Sweep Operation

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93175.htm b/WebHelpDocs/2601B-PULSE/93175.htm new file mode 100644 index 0000000..c528a03 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93175.htm @@ -0,0 +1,101 @@ + + + + + smua.measure.nplc + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.nplc

+

This command sets the integration aperture for measurements when the pulser is disabled.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

1.0

+
+

Usage

+

nplc = smua.measure.nplc

+

smua.measure.nplc = nplc

+

+ + + + + + +

nplc

+

The integration aperture; set from 0.001 to 25

+
+

+

Details

+

This attribute controls the integration aperture for the analog-to-digital converter (ADC) that is used when the pulser is disabled.

+

The integration aperture is based on the number of power line cycles (NPLC), where 1 PLC for 60 Hz is 16.67 ms (1/60) and 1 PLC for 50 Hz is 20 ms (1/50).

+

Example

+

+ + + + + + + + +

smua.measure.nplc = 0.5

+

Sets the integration time to 0.5.

+
+

Also see

+

Speed

+

reset()

+

setup.recall()

+

smua.pulser.measure.aperture

+

smua.reset()

+

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93187.htm b/WebHelpDocs/2601B-PULSE/93187.htm new file mode 100644 index 0000000..bd5aa1f --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93187.htm @@ -0,0 +1,1772 @@ + + + + + Error summary list + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Error summary list

+

+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +

Error summary

+

Error number

+

Error level

+

Error message

+

-430

+

RECOVERABLE

+

Query DEADLOCKED

+

-420

+

RECOVERABLE

+

Query UNTERMINATED

+

-410

+

RECOVERABLE

+

Query INTERRUPTED

+

-363

+

RECOVERABLE

+

Input buffer overrun

+

-360

+

RECOVERABLE

+

Communications error

+

-350

+

RECOVERABLE

+

Queue overflow

+

-315

+

RECOVERABLE

+

Configuration memory lost

+

-314

+

RECOVERABLE

+

Save/recall memory lost

+

-292

+

RECOVERABLE

+

Referenced name does not exist

+

-286

+

RECOVERABLE

+

TSP Runtime error

+

-285

+

RECOVERABLE

+

Program syntax

+

-282

+

RECOVERABLE

+

Illegal program name

+

-281

+

RECOVERABLE

+

Cannot create program

+

-225

+

RECOVERABLE

+

Out of memory or TSP Memory allocation error

+

-224

+

RECOVERABLE

+

Illegal parameter value

+

-222

+

RECOVERABLE

+

Parameter data out of range

+

-221

+

RECOVERABLE

+

Settings conflict

+

-220

+

RECOVERABLE

+

Parameter error

+

-211

+

RECOVERABLE

+

Trigger ignored

+

-203

+

RECOVERABLE

+

Command protected

+

-154

+

RECOVERABLE

+

String too long

+

-151

+

RECOVERABLE

+

Invalid string data

+

-110

+

RECOVERABLE

+

Command header error

+

-109

+

RECOVERABLE

+

Missing parameter

+

-108

+

RECOVERABLE

+

Parameter not allowed

+

-105

+

RECOVERABLE

+

Trigger not allowed

+

-104

+

RECOVERABLE

+

Data type error

+

0

+

NO_SEVERITY

+

Queue Is Empty

+

503

+

RECOVERABLE

+

Calibration overflow

+

601

+

RECOVERABLE

+

Reading buffer data lost

+

603

+

RECOVERABLE

+

Power on state lost

+

702

+

FATAL

+

Unresponsive digital FPGA

+

802

+

RECOVERABLE

+

OUTPUT blocked by interlock

+

819

+

RECOVERABLE

+

Error parsing exponent

+

820

+

RECOVERABLE

+

Error parsing value

+

900

+

FATAL

+

Internal system error

+

1100

+

RECOVERABLE

+

Command unavailable

+

1101

+

RECOVERABLE

+

Parameter too big

+

1102

+

RECOVERABLE

+

Parameter too small

+

1103

+

RECOVERABLE

+

Min greater than max

+

1104

+

RECOVERABLE

+

Too many digits for param type

+

1105

+

RECOVERABLE

+

Too many parameters

+

1107

+

RECOVERABLE

+

Cannot modify factory menu

+

1108

+

RECOVERABLE

+

Menu name does not exist

+

1109

+

RECOVERABLE

+

Menu name already exists

+

1110

+

FATAL

+

Analog supply failure: over temperature

+

1113

+

RECOVERABLE

+

Data too complex

+

1122

+

SERIOUS

+

Interlock or power supply failure

+

1200

+

RECOVERABLE

+

TSP-Link initialization failed

+

1202

+

RECOVERABLE

+

TSP-Link initialization failed

+

1203

+

RECOVERABLE

+

TSP-Link initialization failed (possible loop in node chain)

+

1204

+

RECOVERABLE

+

TSP-Link initialization failed

+

1205

+

RECOVERABLE

+

TSP-Link initialization failed (no remote nodes found)

+

1206

+

RECOVERABLE

+

TSP-Link initialization failed

+

1207

+

RECOVERABLE

+

TSP-Link initialization failed

+

1208

+

RECOVERABLE

+

TSP-Link initialization failed

+

1209

+

RECOVERABLE

+

TSP-Link initialization failed

+

1210

+

RECOVERABLE

+

TSP-Link initialization failed (node ID conflict)

+

1211

+

RECOVERABLE

+

Node NN is inaccessible

+

1212

+

RECOVERABLE

+

Invalid node ID

+

1213

+

RECOVERABLE

+

TSP-Link session expired

+

1215

+

RECOVERABLE

+

Code execution requested within the local group

+

1216

+

RECOVERABLE

+

Remote execution requested on node in group with pending overlapped operations

+

1217

+

RECOVERABLE

+

Remote execution requested on node outside the local group

+

1218

+

RECOVERABLE

+

Operation allowed only when TSP-Link master

+

1219

+

RECOVERABLE

+

TSP-Link found fewer nodes than expected

+

1400

+

RECOVERABLE

+

Expected at least NN parameters

+

1401

+

RECOVERABLE

+

Parameter NN is invalid

+

1402

+

RECOVERABLE

+

User scripts lost

+

1403

+

RECOVERABLE

+

Factory scripts lost

+

1404

+

RECOVERABLE

+

Invalid byte order

+

1405

+

RECOVERABLE

+

Invalid ASCII precision

+

1406

+

RECOVERABLE

+

Invalid data format

+

1500

+

RECOVERABLE

+

Invalid baud rate setting

+

1501

+

RECOVERABLE

+

Invalid parity setting

+

1502

+

RECOVERABLE

+

Invalid terminator setting

+

1503

+

RECOVERABLE

+

Invalid bits setting

+

1504

+

RECOVERABLE

+

Invalid flow control setting

+

1600

+

RECOVERABLE

+

Maximum GPIB message length exceeded

+

1700

+

RECOVERABLE

+

Display area boundary exceeded

+

1800

+

RECOVERABLE

+

Invalid digital trigger mode

+

1801

+

RECOVERABLE

+

Invalid digital I/O line

+

2000

+

SERIOUS

+

Flash download error

+

2001

+

RECOVERABLE

+

Cannot flash with error in queue

+

2101

+

FATAL

+

Could not close socket

+

2102

+

RECOVERABLE

+

Lan configuration already in progress

+

2103

+

RECOVERABLE

+

Lan disabled

+

2104

+

RECOVERABLE

+

Socket error

+

2105

+

RECOVERABLE

+

Unreachable gateway

+

2106

+

RECOVERABLE

+

Could not acquire ip address

+

2110

+

RECOVERABLE

+

Could not resolve hostname

+

2111

+

RECOVERABLE

+

DNS name (FQDN) too long

+

2112

+

RECOVERABLE

+

Connection not established

+

2200

+

RECOVERABLE

+

File write error

+

2201

+

RECOVERABLE

+

File read error

+

2202

+

RECOVERABLE

+

Cannot close file

+

2203

+

RECOVERABLE

+

Cannot open file

+

2204

+

RECOVERABLE

+

Directory not found

+

2205

+

RECOVERABLE

+

File not found

+

2206

+

RECOVERABLE

+

Cannot read current working directory

+

2207

+

RECOVERABLE

+

Cannot change directory

+

2211

+

RECOVERABLE

+

File system error

+

2212

+

RECOVERABLE

+

File system command not supported

+

2213

+

RECOVERABLE

+

Too many open files

+

2214

+

RECOVERABLE

+

File access denied

+

2215

+

RECOVERABLE

+

Invalid file handle

+

2216

+

RECOVERABLE

+

Invalid drive

+

2217

+

RECOVERABLE

+

File system busy

+

2218

+

RECOVERABLE

+

Disk full

+

2219

+

RECOVERABLE

+

File corrupt

+

2220

+

RECOVERABLE

+

File already exists

+

2221

+

RECOVERABLE

+

File seek error

+

2222

+

RECOVERABLE

+

End-of-file error

+

2223

+

RECOVERABLE

+

Directory not empty

+

2400

+

RECOVERABLE

+

Invalid specified connection

+

2401

+

RECOVERABLE

+

Invalid timeout seconds (.001 to 30)

+

2402

+

RECOVERABLE

+

TSPnet remote error: XXX, where XXX explains the remote error

+

2403

+

RECOVERABLE

+

TSPnet failure

+

2404

+

RECOVERABLE

+

TSPnet read failure

+

2405

+

RECOVERABLE

+

TSPnet read failure, aborted

+

2406

+

RECOVERABLE

+

TSPnet read failure, timeout

+

2407

+

RECOVERABLE

+

TSPnet write failure

+

2408

+

RECOVERABLE

+

TSPnet write failure, aborted

+

2409

+

RECOVERABLE

+

TSPnet write failure, timeout

+

2410

+

RECOVERABLE

+

TSPnet max connections reached

+

2411

+

RECOVERABLE

+

TSPnet connection failed

+

2412

+

RECOVERABLE

+

TSPnet invalid termination

+

2413

+

RECOVERABLE

+

TSPnet invalid reading buffer table

+

2414

+

RECOVERABLE

+

TSPnet invalid reading buffer index range

+

2415

+

RECOVERABLE

+

TSPnet feature only supported on TSP connections

+

2416

+

RECOVERABLE

+

TSPnet must specify both port and init

+

2417

+

RECOVERABLE

+

TSPnet disconnected by other side

+

2418

+

RECOVERABLE

+

TSPnet read input buffer overflow

+

2419

+

RECOVERABLE

+

Invalid format specifier

+

2420

+

RECOVERABLE

+

Termination locked while using TSP connection

+

2500

+

RECOVERABLE

+

Average delay must be at least NNN seconds

+

4900

+

RECOVERABLE

+

Reading buffer index NN is invalid

+

4903

+

RECOVERABLE

+

Reading buffer expired

+

4904

+

SERIOUS

+

ICX parameter count mismatch, %s (Line #%d)

+

4905

+

SERIOUS

+

ICX parameter invalid value, %s (Line #%d)

+

4906

+

SERIOUS

+

ICX invalid function id, %s (Line #%d)

+

5001

+

FATAL

+

SMU is unresponsive. Disconnect DUT and cycle power

+

5003

+

SERIOUS

+

Saved calibration constants corrupted

+

5004

+

RECOVERABLE

+

Operation conflicts with CALA sense mode

+

5005

+

RECOVERABLE

+

Value too big for range

+

5007

+

RECOVERABLE

+

Operation would exceed safe operating area of the instrument

+

5008

+

RECOVERABLE

+

Operation not permitted while OUTPUT is on

+

5009

+

SERIOUS

+

Unknown sourcing function

+

5010

+

SERIOUS

+

No such SMU function

+

5011

+

RECOVERABLE

+

Operation not permitted while cal is locked

+

5012

+

RECOVERABLE

+

Cal data not saved - save or restore before lock

+

5013

+

RECOVERABLE

+

Cannot save cal data - unlock before save

+

5014

+

RECOVERABLE

+

Cannot restore cal data - unlock before restore

+

5015

+

RECOVERABLE

+

Save to cal set disallowed

+

5016

+

RECOVERABLE

+

Cannot change cal date - unlock before operation

+

5017

+

RECOVERABLE

+

Cannot change cal constants - unlock before operation

+

5018

+

SERIOUS

+

Cal version inconsistency

+

5019

+

RECOVERABLE

+

Cannot unlock - invalid password

+

5021

+

SERIOUS

+

Cannot restore default calset. Using previous calset

+

5022

+

SERIOUS

+

Cannot restore previous calset. Using factory calset

+

5023

+

SERIOUS

+

Cannot restore factory calset. Using nominal calset

+

5024

+

SERIOUS

+

Cannot restore nominal calset. Using firmware defaults

+

5025

+

RECOVERABLE

+

Cannot set filter.count > 1 when measure.count > 1

+

5027

+

RECOVERABLE

+

Unlock cal data with factory password

+

5028

+

RECOVERABLE

+

Cannot perform requested operation while source autorange is enabled

+

5029

+

RECOVERABLE

+

Cannot save without changing cal adjustment date

+

5032

+

RECOVERABLE

+

Cannot change this setting unless buffer is cleared

+

5033

+

RECOVERABLE

+

Reading buffer not found within device

+

5038

+

RECOVERABLE

+

Index exceeds maximum reading

+

5040

+

RECOVERABLE

+

Cannot use same reading buffer for multiple overlapped measurements

+

5042

+

RECOVERABLE

+

Cannot perform requested action while an overlapped operation is in progress

+

5043

+

RECOVERABLE

+

Cannot perform requested operation while voltage measure autorange is enabled

+

5044

+

RECOVERABLE

+

Cannot perform requested operation while current measure autorange is enabled

+

5045

+

RECOVERABLE

+

Cannot perform requested operation while filter is enabled

+

5046

+

SERIOUS

+

SMU too hot

+

5047

+

RECOVERABLE

+

Minimum timestamp resolution is 1us

+

5048

+

RECOVERABLE

+

Contact check not valid with HIGH-Z OUTPUT off

+

5049

+

RECOVERABLE

+

Contact check not valid while an active current source

+

5050

+

RECOVERABLE

+

I limit too low for contact check

+

5051

+

FATAL

+

Model number/SMU hardware mismatch. Disconnect DUT and cycle power

+

5053

+

RECOVERABLE

+

Unstable output detected - Measurements may not be valid

+

5055

+

RECOVERABLE

+

Cannot change adjustment date - change cal constants before operation

+

5059

+

RECOVERABLE

+

trigger.source.action enabled without configuration

+

5060

+

RECOVERABLE

+

trigger.measure.action enabled without configuration

+

5061

+

RECOVERABLE

+

Operation not permitted while OUTPUT is off

+

5062

+

SERIOUS

+

SMU overload. Automatic OUTPUT off.

+

5063

+

RECOVERABLE

+

Cannot perform requested operation while measure autozero is on

+

5064

+

RECOVERABLE

+

Cannot use reading buffer that collects source values

+

5065

+

RECOVERABLE

+

I range too low for contact check

+

5066

+

RECOVERABLE

+

source.offlimiti too low for contact check

+

5069

+

SERIOUS

+

Autorange locked for HighC mode

+

5108

+

RECOVERABLE

+

Maximum pulse width exceeded

+

5109

+

RECOVERABLE

+

Maximum duty cycle exceeded

+

5111

+

RECOVERABLE

+

Total measure time exceeds pulse width

+

5126

+

RECOVERABLE

+

Operation not permitted while pulser is enabled

+

5127

+

RECOVERABLE

+

Output protection level exceeded

+

5128

+

RECOVERABLE

+

Pulse width too small

+

5129

+

RECOVERABLE

+

Measure time exceeds measure interval

+

5130

+

RECOVERABLE

+

Filter type not permitted while pulser is enabled

+

5131

+

RECOVERABLE

+

Current source as off-function not permitted while pulser is enabled

+

5132

+

RECOVERABLE

+

Voltage sweeps not permitted while pulser is enabled

+

5133

+

RECOVERABLE

+

Measure stimulus not allowed with pulser measure delay when pulser is enabled

+

5134

+

RECOVERABLE

+

Measure stimulus requires asynchronous measure when pulser is enabled

+

5135

+

RECOVERABLE

+

Measure not permitted with output off when pulser is enabled

+

5136

+

RECOVERABLE

+

Measure count too big with pulser enabled

+

5137

+

RECOVERABLE

+

Measure interval too big with pulser enabled

+

5138

+

RECOVERABLE

+

trigger.source.action required when pulser is enabled

+

5139

+

RECOVERABLE

+

trigger.source.stimulus required when pulser is enabled

+

5140

+

RECOVERABLE

+

Measure stimulus or measure delay required when pulser is enabled

+

5141

+

RECOVERABLE

+

Pulse width not permitted when pulser is disabled

+

5142

+

RECOVERABLE

+

Measure count multiplied by filter count is too big

+

5143

+

RECOVERABLE

+

End pulse stimulus or pulse width required when pulser is enabled

+

5144

+

RECOVERABLE

+

Maximum measurement rate exceeded

+

5145

+

RECOVERABLE

+

Maximum pulse rate exceeded

+
+

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93207.htm b/WebHelpDocs/2601B-PULSE/93207.htm new file mode 100644 index 0000000..034a17a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93207.htm @@ -0,0 +1,104 @@ + + + + + smua.measure.autozero + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

smua.measure.autozero

+

This attribute enables or disables automatic updates to the internal reference measurements (autozero) of the instrument.

+ + + + + + + + + + + + + + + + +

Type

+

TSP-Link accessible

+

Affected by

+

Where saved

+

Default value

+

Attribute (RW)

+

Yes

+

Instrument reset
SMU reset
Recall setup

+

Saved setup

+

2 (smua.AUTOZERO_AUTO)

+
+

Usage

+

azMode = smua.measure.autozero

+

smua.measure.autozero = azMode

+

+ + + + + + +

azMode

+

Indicates status of autozero; set to one of the following values:

+
  • 0 or smua.AUTOZERO_OFF: Autozero disabled
  • 1 or smua.AUTOZERO_ONCE: Performs autozero once, then disables autozero
  • 2 or smua.AUTOZERO_AUTO: Automatic checking of reference and zero measurements; an autozero is performed when needed
+

+

Details

+

The analog-to-digital converter (ADC) uses a ratiometric A/D conversion technique. To ensure the accuracy of readings, the instrument must periodically obtain new measurements of its internal ground and voltage reference. The time interval between updates to these reference measurements is determined by the integration aperture being used for measurements. The 2601B-PULSE uses separate reference and zero measurements for each aperture.

+

By default, the instrument automatically checks these reference measurements whenever a signal measurement is made. If the reference measurements have expired when a signal measurement is made, the instrument will automatically take two more A/D conversions, one for the reference and one for the zero, before returning the result. Thus, occasionally, a measurement takes longer than normal.

+

This additional time can cause problems in sweeps and other test sequences in which measurement timing is critical. To avoid the time that is needed for the reference measurements in these situations, you can use the smua.measure.autozero attribute to disable the automatic reference measurements.

+

Disabling automatic reference measurements may allow the instrument to gradually drift out of specification. To minimize the drift, a reference and zero measurement should be made immediately before any critical test sequences. You can use the smua.AUTOZERO_ONCE setting to force a refresh of the reference and zero measurements that are used for the present aperture setting.

+

The 2601B-PULSE stores the reference measurements for the last ten NPLC settings that were used in a reference cache. If an NPLC setting is selected and an entry for it is not in the cache, the oldest (least recently used) entry is discarded to make room for the new entry.

+

When the pulser is enabled, two high-speed digitizing sampling ADCs are used to measure voltage and current. These ADCs do not use a ratiometric conversion technique, so the autozero settings are ignored when the pulser is enabled.

+

Example

+

+ + + + + + + + +

smua.measure.autozero = smua.AUTOZERO_ONCE

+

Performs autozero once.

+
+

Also see

+

Autozero

+

reset()

+

smua.measure.nplc

+

setup.recall()

+

smua.reset()

+ + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93212.htm b/WebHelpDocs/2601B-PULSE/93212.htm new file mode 100644 index 0000000..20a05ec --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93212.htm @@ -0,0 +1,44 @@ + + + + + Front panel + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Front panel

+

See the "Front panel" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93213.htm b/WebHelpDocs/2601B-PULSE/93213.htm new file mode 100644 index 0000000..3d3f266 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93213.htm @@ -0,0 +1,42 @@ + + + + + Using the interlock + + + + + + + + +
+

Previous Icon

+

Using the interlock

+

See the "Using the interlock" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93214.htm b/WebHelpDocs/2601B-PULSE/93214.htm new file mode 100644 index 0000000..e2fedca --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93214.htm @@ -0,0 +1,44 @@ + + + + + Pulser operation + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Pulser operation

+

See the "Pulser operation" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Upgrading the firmware

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/93219.htm b/WebHelpDocs/2601B-PULSE/93219.htm new file mode 100644 index 0000000..e1fda1a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/93219.htm @@ -0,0 +1,44 @@ + + + + + Upgrading the firmware + + + + + + + + + +
+

Previous Icon

+

Next Icon

+

Upgrading the firmware

+

See the "Upgrading the firmware" topic in the 2601B-PULSE reference manual.

+ + + + +
+

See also

Additional information

2-wire local sensing connections

4-wire remote sensing connections

Adjustment

Analog-to-digital converter

Anonymous scripts

Autoranging

Autozero

Base library functions

Calibration

Capturing key-press codes

Configuring and running sweeps

Contact check connections

Contact check measurements

Controlling digital I/O lines

Create a script using the script.new() command

Delete user scripts

Delete user scripts from the instrument

Digital I/O

Digital I/O bit weighting

Digital I/O port

Display mode

Display resolution

DUT test connections

Error queue

Error summary list

Filters

Front panel

Global variables and the script.user.scripts table

GPIB setup

High-capacitance mode

Load a script by sending commands over the remote interface

Logical operators

Measure auto delay

Measurement event registers

Named scripts

Operation Status Registers

Output-off states

Pulser operation

Questionable Status Registers

Queues

Range

Overview

Relative offset

Remote reading buffer programming

Removing stale values from the reading buffer cache

Rename a script

Retrieve source code one line at a time

RS-232 interface operation

Save a user script

Saved setups

Sense mode selection

Setting a value

Source or sink

Source-measure concepts

Speed

Standard Event Register

Start-up (power-on) configuration

Status byte and service request (SRQ)

Status model

Status model overview

Sweep operation

System summary and standard event registers

Triggering

TSP advanced features

TSP-Link

TSP-Link trigger lines

Understanding hardware value and pseudo line state

Using groups to manage nodes on TSP-Link network

Using the data queue for real-time communication

Using the interlock

+ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/AfterPublish.bat b/WebHelpDocs/2601B-PULSE/AfterPublish.bat new file mode 100644 index 0000000..9068f2b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/AfterPublish.bat @@ -0,0 +1,19 @@ +::-------------------------------------------------- +:: AfterPublishing.bat - Runs OracleToEclipse +::-------------------------------------------------- + +@echo off + +::Get the current batch file's short path +for %%x in (%0) do set BatchPath=%%~dpsx +for %%x in (%BatchPath%) do set BatchPath=%%~dpsx +echo BatchPath = %BatchPath% + +echo "Enter ShortName (2600B, 3700, 707B, 2651A, 2657A, 2450, 2460):" +set /p ShortName= + +echo "ShortName is " %ShortName% + +cd %BatchPath% +OracleToEclipse toc.xml %ShortName% + diff --git a/WebHelpDocs/2601B-PULSE/EclipseHelpTemplate.html b/WebHelpDocs/2601B-PULSE/EclipseHelpTemplate.html new file mode 100644 index 0000000000000000000000000000000000000000..40cd810d0c2e321c7c67a89af3067b697a299503 GIT binary patch literal 1476 zcmb`H-A>y;5QWcmrM`oe-V}+(B?4517OCQ@Dlg&0365$U%XZr!)K_o&%`9sZL;^xw z_-AL&%$)iC_xH03b-GrmbG_9Y*?FN%d4KM-0#PD8=QibkI0uaqNu?i3)PO4WMI*J~ zZd|K%iwn*p5GJib8K&dA;hky@zV-XUZ7g@%7~jLDJ;%Y@QyxN;IgEd44Ch*FJSV!< zZ)7=a3QcvY6CHE6(HVCZ`;wcfKK8PpXPH=Gq2g}I-v(rk&L7WZM;>RcZT4s28g3W7 zr#f;=3BK1L%yXi5y1+wx%yaFPFt(Mh^x;t^OQdUX#;`E)To)_Axu5rlFz_xy{Lr)#bJATGn&= z{dMdXnvl)y3{L2Ykl%eiLcB9NVK*vZZ2F$UgqcsNXq@o4Inth8l*A0gbC|ottDa$@ z^*N7IIJ%qX;2|Tjj{I3?XInQG$uRrIc{tVZx1JiTM-Fk@n3oGGQ&X7+A6KyM(0Y&F z0pAHTc%)A{ + + + +Model 2601B-PULSE TSB help files + + + + O19545 + + + + + + + oracle.help.navigator.tocNavigator.TOCNavigator + toc.xml + + + + oracle.help.navigator.searchNavigator.SearchNavigator + search.idx + + + diff --git a/WebHelpDocs/2601B-PULSE/OracleToEclipse.exe b/WebHelpDocs/2601B-PULSE/OracleToEclipse.exe new file mode 100644 index 0000000000000000000000000000000000000000..696ed36f0ab14f2f5e3172cc7a10238452e08dc3 GIT binary patch literal 16384 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 T2*e1)2*e1)2*e0H*a-X=4@rJ< literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/OracleToEclipse.xslt b/WebHelpDocs/2601B-PULSE/OracleToEclipse.xslt new file mode 100644 index 0000000..73c713c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/OracleToEclipse.xslt @@ -0,0 +1,28 @@ + + + + + + + + + /.html + + + + + + + + + _toc.xml + + + + + + + + + + \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/caution_large_no_exclaim_lr.png b/WebHelpDocs/2601B-PULSE/caution_large_no_exclaim_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..1bfee3baad58143f2c9feda7624cb1905ceb0825 GIT binary patch literal 943 zcmV;g15o^lP)pIVM#Q_Mjutft5xCvcOb|0?h{* zqOj;qNP38tJz7E0LkUq2!J>y?qloGu4H9J1Ad!}cO<_s0?O~H3!?gwOZug!Z&fMWY7} zUy^B!Ra*@*CGkhk##&+DvEO&r5-})0wp;>0AF-HN+eK??=%KAcq}l>NTwi00&z0%X z{OF+pYIAC{uAGzBSWR|!`h_ExsHw4w+MMcxMw8vW1={IRH8!VTBH5hu=wLQWT|~Y! zTY8h4xcsMB+d?bWbqc5Nu%$Q3_$8(!c-~@cE)(`<*=_1&>uaQ`k9>6fli>6VM;5=` ztt~uLgX6rmyo}s9R6eRDVxpy8XdjU(b}CcXvJo4)#Lwfo1dQxt@$dlqI-lcGnRQ7! z&D3%NVJ`q--!W2c$&6hP&ps6EI?_w8|Grzk+5mn;^99*JOC*^d9n^P9I^ZGF4r+4} zzl(d=`kHX+w)*7cKglg!rE1&Q@}%COOkK;-ELgi)Jd_E05%JL$hXKl2V+Ejwe0pal zv$? zD*$cvOaA-^Jc#&&Q@2TlY-lG(e59$D$KzJfd0py#41l&cSUkj*C$*@bEl(oiBlTy9 zBx|cd00nte$SfWzs;b|E{D2f(3Wo*&sIdaoO?j^a5ZbO9sZwdb%Vc+(j$g^lKh0LJ zwoM(oK&s4SZ?ifvoKq$tHfOTC#m1g=z{7=vjbG%VN}BrEm$yZxrA`bBr|(qC`!k=O zvQ$E_cGH9X+QPFKX0mUh&(74t}+ zS3s)FM3Q-@mGt~7=AmO$M8jT=EE#2`N=`DWCZqqaSfxk&8(Ol*T0VaUzW|5lsj;-Z R`M>}G002ovPDHLkV1nZa$^-xa literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/contents1.gif b/WebHelpDocs/2601B-PULSE/contents1.gif new file mode 100644 index 0000000000000000000000000000000000000000..18ec6645be36a538631cb12daf6e87104a54bf4c GIT binary patch literal 1057 zcmZ?wbhEHb3}BFE_|59H_t$9SGO7IH(6}~cau`c@$bxJ0vTo0_<=(F6xheI08LPvBm$%lJ+&w32 zWBx8-hv-H#)9xt_@%u%3vsh!cuT43Wz^xHi^KIj;6ZNd|ZaPzoULL71&3pRWa!bbL z^@gX_-j;s8c+L0eCDqy+YZDK)AG{Uj^(XDsqZ5XF{^w#oe|&afy0gAst<}fp*Cr>Q WkE^jRUwUsp`)?loeQ6F14AuZDyK~q8 literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/contents2.gif b/WebHelpDocs/2601B-PULSE/contents2.gif new file mode 100644 index 0000000000000000000000000000000000000000..aac273626bff61025db0efe7688d66a00c515f0e GIT binary patch literal 1058 zcmZ?wbhEHb^ka}__|5)1(2lJSt}#XLyp(gRL^o=S-Cd=>T;H?rtV}&C=Wtt;fw3j5H>>ye zwhz%eTREFWUI=}NTf*{>NzOaGAZbYyd)l(=c Xy1y3R-+ArlXx^_`XLF{3fx#L8r%-Ws literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/contents3.gif b/WebHelpDocs/2601B-PULSE/contents3.gif new file mode 100644 index 0000000000000000000000000000000000000000..9fef3ca8abfa09a8e3be01e340f894cf5edf840f GIT binary patch literal 1058 zcmZ?wbhEHb^ka}__|5t%*&gONLXh;lKoy;8ivr z51yQwt{*Mta8sbcbA|=`sU<5fJZoe&FFtf<=Y{9z=Q|4C+M-#ac(KK;U#Zp0K=bM> zuK8NJ3=XdXS2G_p5~-fB#$jzLf5BI-kTucEVs_qZ*&VXLb64@&MZUYmG#O^H9c0^U zZNBc|juKw+YcDsgxV4mpfqh=i_YbkVz4gQ8athX8I&Sn(Oho3|rbic-PJWeZBc{Q4 zaf + + + + + + + + + + + \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/dhtml_search.js b/WebHelpDocs/2601B-PULSE/dhtml_search.js new file mode 100644 index 0000000..39feb8e --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/dhtml_search.js @@ -0,0 +1,628 @@ +/* Generated with Author-it 6.4.3.37098 4/14/2020 1:30:43 PM */ +Page=new Array();Page[0]=new Array("Instruments that are enabled for Test Script Processor (TSP®) operate like conventional instruments by responding to a sequence of commands sent by the controller. You can send individual commands to the TSP-enabled instrument the same way you would when using any other instrument. ","Unlike conventional instruments, TSP-enabled instruments can execute automated test sequences independently, without an external controller. You can load a series of TSP commands into the instrument. You can store these commands as a script that can be run later by sending a single command message to the instrument.","You do not have to choose between using conventional control or script control. You can combine these forms of instrument control in the way that works best for your test application.","Introduction to TSP operation","17029.htm"); +Page[1]=new Array("The simplest method of controlling an instrument through the communication interface is to send it a message that contains remote commands. You can use a test program that resides on a computer (the controller) to sequence the actions of the instrument.","TSP commands can be function-based or attribute-based. Function-based commands are commands that control actions or activities. Attribute-based commands define characteristics of an instrument feature or operation.","Constants represent fixed values.","Controlling the instrument by sending individual command messages","17268.htm"); +Page[2]=new Array("Function-based commands control actions or activities. A function-based command performs an immediate action on the instrument.","Each function consists of a function name followed by a set of parentheses ( ). You should only include information in the parentheses if the function takes a parameter. If the function takes one or more parameters, they are placed between the parentheses and separated by commas.","Example 1","beeper.beep(0.5, 2400)","delay(0.250)","beeper.beep(0.5, 2400)","Emit a double‑beep at 2400 Hz. The sequence is 0.5 s on, 0.25 s off, 0.5 s on.","Example 2","You can use the results of a function-based command directly or assign the results to variables for later access. The following code defines x and prints it.","x = math.abs(-100)","print(x)","Output:","100","Functions","13811.htm"); +Page[3]=new Array("Attribute-based commands are commands that set the characteristics of an instrument feature or operation. For example, a characteristic of TSP‑enabled instruments is the model number (localnode.model).","Attributes can be read-only, read-write, or write-only. They can be used as a parameter of a function or assigned to another variable.","Attributes","492.htm"); +Page[4]=new Array("To set the characteristics, attribute-based commands define a value. For many attributes, the value is in the form of a number or a predefined constant.","Example 1: Set an attribute using a number","beeper.enable = 0","This attribute controls the beeps that occur when front‑panel controls are selected. Setting this attribute to 0 turns off the beeper.","Example 2: Set an attribute using a constant","format.data = format.REAL64","Using the constant REAL64 sets the print format to double precision floating-point format.","","492.htm#o493"); +Page[5]=new Array("To read an attribute, you can use the attribute as the parameter of a function, or assign it to another variable.","Example 3: Read an attribute using a function","print(format.data)","Reads the data format by passing the attribute to the print function. If the data format is set to 3, the output is:","3.00000e+00","This shows that the data format is set to double precision floating point.","Example 4: Read an attribute using a variable","fd = format.data","This reads the data format by assigning the attribute to a variable named fd.","","492.htm#o494"); +Page[6]=new Array("Test Script Processor (TSP®) enabled instruments do not have inherent query commands. Like any other scripting environment, the print() and printnumber() commands generate output in the form of response messages. Each print() command creates one response message.","Example","x = 10","print(x)","Example of an output response message: ","10","Note that your output may be different if you set your ASCII precision setting to a different value.","Queries","368.htm"); +Page[7]=new Array("If you need information about using scripts with your TSP‑enabled instrument, see Fundamentals of scripting for TSP.","If you need information about using the Lua programming language with the instrument, see Fundamentals of programming for TSP.","Information on scripting and programming","17789.htm"); +Page[8]=new Array("This section contains an overview of the TSP commands for the instrument. The commands are organized into groups, with a brief description of each group. Each section contains links to the detailed descriptions for each command in the TSP command reference section of this documentation (see TSP commands).","About TSP commands","13401.htm"); +Page[9]=new Array("The beeper commands allow you to enable or disable and sound the instrument beeper.","beeper.beep()","beeper.enable","Beeper control","14127.htm"); +Page[10]=new Array("The bit functions perform bitwise logic operations on two given numbers, and bit operations on one given number. Logic and bit operations truncate the fractional part of given numbers to make them integers.","Logic operations","The bit.bitand(), bit.bitor(), and bit.bitxor() functions in this group perform bitwise logic operations on two numbers. The Test Script Processor (TSP®) scripting engine performs the indicated logic operation on the binary equivalents of the two integers. This bitwise logic operation is performed on all corresponding bits of the two numbers. The result of a logic operation is returned as an integer.","Bit operations","The rest of the functions in this group are used for operations on the bits of a given number. These functions can be used to:","Clear a bit","Toggle a bit","Test a bit","Set a bit or bit field","Retrieve the weighted value of a bit or field value","All these functions use an index parameter to specify the bit position of the given number. The least significant bit of a given number has an index of 1, and the most significant bit has an index of 32.","@The Test Script Processor (TSP) scripting engine stores all numbers internally as IEEE Std 754 double-precision floating-point values. The logical operations work on 32‑bit integers. Any fractional bits are truncated. For numbers larger than 4294967295, only the lower 32 bits are used.","bit.bitand()","bit.bitor()","bit.bitxor()","bit.clear()","bit.get()","bit.getfield()","bit.set()","bit.setfield()","bit.test()","bit.toggle()","Bit manipulation and logic operations","11382.htm"); +Page[11]=new Array("smua.cal.adjustdate","smua.cal.date","smua.cal.due","smua.cal.lock()","smua.cal.password","smua.cal.polarity","smua.cal.restore()","smua.cal.save()","smua.cal.state","smua.cal.unlock()","smua.contact.calibratehi()","smua.contact.calibratelo()","smua.measure.calibrateY()","smua.pulser.measure.calibrateY()","smua.pulser.source.calibratebiasi()","smua.pulser.source.calibratei()","smua.source.calibrateY()","Calibration","92710.htm"); +Page[12]=new Array("Use the data queue commands to:","Share data between test scripts running in parallel","Access data from a remote group or a local node on a TSP‑Link® network at any time","The data queue in the Test Script Processor (TSP®) scripting engine is first-in, first-out (FIFO).","You can access data from the data queue even if a remote group or a node has overlapped operations in process.","dataqueue.add()","dataqueue.CAPACITY","dataqueue.clear()","dataqueue.count","dataqueue.next()","Data queue","14653.htm"); +Page[13]=new Array("The digital I/O port of the instrument can control external circuitry (such as a component handler for binning operations).","The I/O port has 14 lines. Each line can be at TTL logic state 1 (high) or 0 (low). See the pinout diagram in Digital I/O port for additional information.","There are commands to read and write to each individual bit, and commands to read and write to the entire port.","digio.readbit()","digio.readport()","digio.trigger[N].assert()","digio.trigger[N].clear()","digio.trigger[N].EVENT_ID","digio.trigger[N].mode","digio.trigger[N].overrun","digio.trigger[N].pulsewidth","digio.trigger[N].release()","digio.trigger[N].reset()","digio.trigger[N].stimulus","digio.trigger[N].wait()","digio.writebit()","digio.writeport()","digio.writeprotect","Digital I/O","77502.htm"); +Page[14]=new Array("display.clear()","display.getannunciators()","display.getcursor()","display.getlastkey()","display.gettext()","display.inputvalue()","display.loadmenu.add()","display.loadmenu.catalog()","display.loadmenu.delete()","display.locallockout","display.menu()","display.numpad","display.prompt()","display.screen","display.sendkey()","display.setcursor()","display.settext()","display.smua.digits","display.smua.limit.func","display.smua.measure.func","display.trigger.clear()","display.trigger.EVENT_ID","display.trigger.overrun","display.trigger.wait()","display.waitkey()","Display","15965.htm"); +Page[15]=new Array("When errors and events occur, the error and status messages are placed in the error queue. Use the error queue commands to request error and status message information.","errorqueue.clear()","errorqueue.count","errorqueue.next()","Error queue","14748.htm"); +Page[16]=new Array("You can use the event log to view specific details about LAN triggering events.","eventlog.all()","eventlog.clear()","eventlog.count","eventlog.enable","eventlog.next()","eventlog.overwritemethod","Event log","10905.htm"); +Page[17]=new Array("You can use the file I/O commands to open and close directories and files, write data, or to read a file on an installed USB flash drive. File I/O commands are organized into two groups:","Commands that reside in the fs and io table, for example: io.open(), io.close(), io.input(), and io.output(). Use these commands to manage file system directories; open and close file descriptors; and perform basic I/O operations on a pair of default files (one input and one output).","Commands that reside in the file descriptors (for example: fileVar:seek(), fileVar:write(), and fileVar:read()) operate exclusively on the file with which they are associated.","The root folder of the USB flash drive has the absolute path:",""/usb1/"","@You can use either the slash (/) or backslash (\\) as a directory separator. However, the backslash is also used as an escape character, so if you use it as a directory separator, you will generally need to use a double backslash (\\\\) when you are creating scripts or sending commands to the instrument.","For basic information about navigation and directory listing of files on a flash drive, see File system navigation.","File descriptor commands for file I/O use a colon (:) to separate the command parts rather than a period (.), like the io commands.","File descriptors cannot be passed between nodes in a TSP-Link® system, so the io.open(), fileVar::read(), and fileVar::write commands are not accessible to the TSP-Link system. However, the default input and output files mentioned above allow for the execution of many file I/O operations without any reference to a file descriptor.","fileVar:close()","fileVar:flush()","fileVar:read()","fileVar:seek()","fileVar:write()","fs.chdir()","fs.cwd()","fs.is_dir()","fs.is_file()","fs.mkdir()","fs.readdir()","fs.rmdir()","io.close()","io.flush()","io.input()","io.open()","io.output()","io.read()","io.type()","io.write()","os.remove()","os.rename()","The following standard I/O commands are not supported:","File","I/O","fileVar:lines()","fileVar:setvbuf()","io.lines()","io.popen()","File I/O","14771.htm"); +Page[18]=new Array("This attribute stores the GPIB address.","gpib.address","GPIB","14859.htm"); +Page[19]=new Array("These commands store strings that describe the instrument.","localnode.description","localnode.model","localnode.revision","localnode.serialno","Instrument identification","19423.htm"); +Page[20]=new Array("The LAN commands have options that allow you to review and configure network settings.","The lan.config.* commands allow you to configure LAN settings over the remote interface. Note that you must send lan.applysettings() for the configuration settings to take effect.","The lan.status.* commands help you determine the status of the LAN.","The lan.trigger[N].* commands allow you to set up and assert trigger events that are sent over the LAN.","Other LAN commands allow you to reset the LAN, restore defaults, check LXI domain information, and enable or disable the Nagle algorithm.","lan.applysettings()","lan.autoconnect","lan.config.dns.address[N]","lan.config.dns.domain","lan.config.dns.dynamic","lan.config.dns.hostname","lan.config.dns.verify","lan.config.duplex","lan.config.gateway","lan.config.ipaddress","lan.config.method","lan.config.speed","lan.config.subnetmask","lan.linktimeout","lan.lxidomain","lan.nagle","lan.reset()","lan.restoredefaults()","lan.status.dns.address[N]","lan.status.dns.name","lan.status.duplex","lan.status.gateway","lan.status.ipaddress","lan.status.macaddress","lan.status.port.dst","lan.status.port.rawsocket","lan.status.port.telnet","lan.status.port.vxi11","lan.status.speed","lan.status.subnetmask","lan.timedwait","lan.trigger[N].assert()","lan.trigger[N].clear()","lan.trigger[N].connect()","lan.trigger[N].connected","lan.trigger[N].disconnect()","lan.trigger[N].EVENT_ID","lan.trigger[N].ipaddress","lan.trigger[N].mode","lan.trigger[N].overrun","lan.trigger[N].protocol","lan.trigger[N].pseudostate","lan.trigger[N].stimulus","lan.trigger[N].wait()","localnode.description","localnode.password","localnode.passwordmode","LAN and LXI","14129.htm"); +Page[21]=new Array("delay()","exit()","localnode.autolinefreq","localnode.linefreq","makegetter()","makesetter()","meminfo()","opc()","waitcomplete()","Miscellaneous","19424.htm"); +Page[22]=new Array("dataqueue.add()","dataqueue.CAPACITY","dataqueue.clear()","dataqueue.count","dataqueue.next()","node[N].execute()","node[N].getglobal()","node[N].setglobal()","tsplink.group","tsplink.master","tsplink.node","Parallel script execution","19425.htm"); +Page[23]=new Array("You can use the print(), printbuffer(), and printnumber() functions to query the instrument and generate response messages. The format attributes control how the data is formatted for the print functions used.","The localnode commands determine if generated errors are automatically sent and if prompts are generated.","format.asciiprecision","format.byteorder","format.data","localnode.prompts","localnode.prompts4882","localnode.showerrors","print()","printbuffer()","printnumber()","Queries and response messages","14795.htm"); +Page[24]=new Array("Reading buffers capture measurements, ranges, instrument status, and output states of the instrument.","bufferVar.appendmode","bufferVar.basetimestamp","bufferVar.cachemode","bufferVar.capacity","bufferVar.clear()","bufferVar.clearcache()","bufferVar.collectsourcevalues","bufferVar.collecttimestamps","bufferVar.fillcount","bufferVar.fillmode","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestampresolution","bufferVar.timestamps","savebuffer()","smua.buffer.getstats()","smua.buffer.recalculatestats()","smua.makebuffer()","smua.nvbufferY","smua.savebuffer()","Reading buffer","17112.htm"); +Page[25]=new Array("Resets settings to their default settings.","digio.trigger[N].reset()","lan.reset()","localnode.reset()","reset()","smua.reset()","timer.reset()","trigger.blender[N].reset()","trigger.timer[N].reset()","tsplink.trigger[N].reset()","Reset","15061.htm"); +Page[26]=new Array("serial.baud","serial.databits","serial.flowcontrol","serial.parity","serial.read()","serial.write()","RS-232","15067.htm"); +Page[27]=new Array("Use the saved setups commands to save or restore the configurations to or from the nonvolatile memory of the instrument or an installed USB flash drive. You can use the setup.poweron attribute to specify which setup is recalled when the instrument is turned on.","setup.poweron","setup.recall()","setup.save()","Saved setups","19516.htm"); +Page[28]=new Array("Scripting helps you combine commands into a block of code that the instrument can run. Scripts help you communicate with the instrument efficiently. These commands describe how to create, load, modify, run, and exit scripts.","For detail on using scripts, see Fundamentals of scripting for TSP.","exit()","makegetter()","makesetter()","script.anonymous","script.delete()","script.factory.catalog()","script.load()","script.new()","script.newautorun()","script.restore()","script.run()","script.user.catalog()","scriptVar.autorun","scriptVar.list()","scriptVar.name","scriptVar.run()","scriptVar.save()","scriptVar.source","Scripting","15062.htm"); +Page[29]=new Array("localnode.linefreq","smua.abort()","smua.buffer.getstats()","smua.buffer.recalculatestats()","smua.contact.check()","smua.contact.r()","smua.contact.speed","smua.contact.threshold","smua.makebuffer()","smua.measure.autorangeY","smua.measure.autozero","smua.measure.count","smua.measure.delay","smua.measure.delayfactor","smua.measure.filter.count","smua.measure.filter.enable","smua.measure.filter.type ","smua.measure.highcrangedelayfactor ","smua.measure.interval","smua.measure.lowrangeY","smua.measure.nplc","smua.measure.overlappedY()","smua.measure.rangeY","smua.measure.rel.enableY","smua.measure.rel.levelY","smua.measure.Y()","smua.measureYandstep()","smua.nvbufferY","smua.pulser.enable","smua.pulser.measure.aperture","smua.pulser.measure.delay","smua.pulser.protect.sensev","smua.pulser.protect.sourcev","smua.pulser.protect.tripped","smua.pulser.rangeY","smua.reset()","smua.savebuffer()","smua.sense","smua.source.autorangeY","smua.source.compliance","smua.source.delay","smua.source.func","smua.source.highc","smua.source.levelY","smua.source.limitY","smua.source.lowrangeY","smua.source.offlimitY","smua.source.offmode","smua.source.output","smua.source.rangeY","smua.source.settling","smua.trigger.arm.count","smua.trigger.arm.set()","smua.trigger.arm.stimulus","smua.trigger.ARMED_EVENT_ID","smua.trigger.autoclear","smua.trigger.count","smua.trigger.endpulse.action","smua.trigger.endpulse.set()","smua.trigger.endpulse.stimulus","smua.trigger.endsweep.action","smua.trigger.IDLE_EVENT_ID","smua.trigger.initiate()","smua.trigger.measure.action","smua.trigger.measure.set()","smua.trigger.measure.stimulus","smua.trigger.measure.Y()","smua.trigger.MEASURE_COMPLETE_EVENT_ID","smua.trigger.PULSE_COMPLETE_EVENT_ID","smua.trigger.source.action","smua.trigger.source.limitY","smua.trigger.source.linearY()","smua.trigger.source.listY()","smua.trigger.source.logY()","smua.trigger.source.pulsewidth","smua.trigger.source.set()","smua.trigger.source.stimulus","smua.trigger.SOURCE_COMPLETE_EVENT_ID","smua.trigger.SWEEP_COMPLETE_EVENT_ID","smua.trigger.SWEEPING_EVENT_ID","SMU","93150.htm"); +Page[30]=new Array("The status model is a set of status registers and queues. You can use the following commands to manipulate and monitor these registers and queues to view and control various instrument events.","status.condition","status.measurement.*","status.measurement.buffer_available.*","status.measurement.current_limit.*","status.measurement.instrument.*","status.measurement.instrument.smua.*","status.measurement.reading_overflow.*","status.measurement.voltage_limit.*","status.node_enable","status.node_event","status.operation.*","status.operation.calibrating.*","status.operation.instrument.*","status.operation.instrument.digio.*","status.operation.instrument.digio.trigger_overrun.*","status.operation.instrument.lan.*","status.operation.instrument.lan.trigger_overrun.*","status.operation.instrument.smua.*","status.operation.instrument.smua.trigger_overrrun.*","status.operation.instrument.trigger_blender.*","status.operation.instrument.trigger_blender.trigger_overrun.*","status.operation.instrument.trigger_timer.*","status.operation.instrument.trigger_timer.trigger_overrun.*","status.operation.instrument.tsplink.*","status.operation.instrument.tsplink.trigger_overrun.*","status.operation.measuring.*","status.operation.remote.*","status.operation.sweeping.*","status.operation.trigger_overrun.*","status.operation.user.*","status.questionable.*","status.questionable.calibration.*","status.questionable.instrument.*","status.questionable.instrument.smua.*","status.questionable.over_temperature.*","status.questionable.unstable_output.*","status.request_enable","status.request_event","status.reset()","status.standard.*","status.system.*","status.system2.*","status.system3.*","status.system4.*","status.system5.*","Status model","14126.htm"); +Page[31]=new Array("bufferVar.basetimestamp","bufferVar.collecttimestamps","bufferVar.timestampresolution","bufferVar.timestamps","delay()","gettimezone()","os.time()","settime()","settimezone()","timer.measure.t()","timer.reset()","Time","19432.htm"); +Page[32]=new Array("Triggering allows you to capture measurements when an input signal or combination of input signals meet a set of conditions that you set. See Sweep operation for details on sweeping.","digio.trigger[N].assert()","digio.trigger[N].clear()","digio.trigger[N].EVENT_ID","digio.trigger[N].mode","digio.trigger[N].overrun","digio.trigger[N].pulsewidth","digio.trigger[N].release()","digio.trigger[N].reset()","digio.trigger[N].stimulus","digio.trigger[N].wait()","display.trigger.clear()","display.trigger.EVENT_ID","display.trigger.overrun","display.trigger.wait()","lan.trigger[N].assert()","lan.trigger[N].clear()","lan.trigger[N].connect()","lan.trigger[N].connected","lan.trigger[N].disconnect()","lan.trigger[N].EVENT_ID","lan.trigger[N].ipaddress","lan.trigger[N].mode","lan.trigger[N].overrun","lan.trigger[N].protocol","lan.trigger[N].pseudostate","lan.trigger[N].stimulus","lan.trigger[N].wait()","smua.pulser.measure.delay","smua.trigger.arm.count","smua.trigger.arm.set()","smua.trigger.arm.stimulus","smua.trigger.ARMED_EVENT_ID","smua.trigger.autoclear","smua.trigger.count","smua.trigger.endpulse.action","smua.trigger.endpulse.set()","smua.trigger.endpulse.stimulus","smua.trigger.endsweep.action","smua.trigger.IDLE_EVENT_ID","smua.trigger.initiate()","smua.trigger.measure.action","smua.trigger.measure.set()","smua.trigger.measure.stimulus","smua.trigger.measure.Y()","smua.trigger.MEASURE_COMPLETE_EVENT_ID","smua.trigger.PULSE_COMPLETE_EVENT_ID","smua.trigger.source.action","smua.trigger.source.limitY","smua.trigger.source.linearY()","smua.trigger.source.listY()","smua.trigger.source.logY()","smua.trigger.source.pulsewidth","smua.trigger.source.set()","smua.trigger.source.stimulus","smua.trigger.SOURCE_COMPLETE_EVENT_ID","smua.trigger.SWEEP_COMPLETE_EVENT_ID","smua.trigger.SWEEPING_EVENT_ID","trigger.blender[N].clear()","trigger.blender[N].EVENT_ID","trigger.blender[N].orenable","trigger.blender[N].overrun","trigger.blender[N].reset()","trigger.blender[N].stimulus[M]","trigger.blender[N].wait()","trigger.clear()","trigger.EVENT_ID","trigger.generator[N].assert()","trigger.generator[N].EVENT_ID","trigger.timer[N].clear()","trigger.timer[N].count","trigger.timer[N].delay","trigger.timer[N].delaylist","trigger.timer[N].EVENT_ID","trigger.timer[N].overrun","trigger.timer[N].passthrough","trigger.timer[N].reset()","trigger.timer[N].stimulus","trigger.timer[N].wait()","trigger.wait()","tsplink.trigger[N].assert()","tsplink.trigger[N].clear()","tsplink.trigger[N].EVENT_ID","tsplink.trigger[N].mode","tsplink.trigger[N].overrun","tsplink.trigger[N].pulsewidth","tsplink.trigger[N].release()","tsplink.trigger[N].reset()","tsplink.trigger[N].stimulus","tsplink.trigger[N].wait()","Triggering","93152.htm"); +Page[33]=new Array("These functions and attributes allow you to set up and work with a system that is connected by a TSP‑Link® network.","tsplink.group","tsplink.master","tsplink.node","tsplink.readbit()","tsplink.readport()","tsplink.reset()","tsplink.state","tsplink.trigger[N].assert()","tsplink.trigger[N].clear()","tsplink.trigger[N].EVENT_ID","tsplink.trigger[N].mode","tsplink.trigger[N].overrun","tsplink.trigger[N].pulsewidth","tsplink.trigger[N].release()","tsplink.trigger[N].reset()","tsplink.trigger[N].stimulus","tsplink.trigger[N].wait()","tsplink.writebit()","tsplink.writeport()","tsplink.writeprotect","TSP-Link","77377.htm"); +Page[34]=new Array("The TSP-Net module provides a simple socket-like programming interface to Test Script Processor (TSP®) enabled instruments.","tspnet.clear()","tspnet.connect()","tspnet.disconnect()","tspnet.execute()","tspnet.idn()","tspnet.read()","tspnet.readavailable()","tspnet.reset()","tspnet.termination()","tspnet.timeout","tspnet.tsp.abort()","tspnet.tsp.abortonconnect","tspnet.tsp.rbtablecopy()","tspnet.tsp.runscript()","tspnet.write()","TSP-Net","14072.htm"); +Page[35]=new Array("Use the functions in this group to store and retrieve user-defined strings in nonvolatile memory. These strings are stored as key‑value pairs. The key is a unique identifier such as a part number or identification string.","You can use the userstring functions to store custom, instrument-specific information in the instrument, such as department number, asset number, or manufacturing plant location.","userstring.add()","userstring.catalog()","userstring.delete()","userstring.get()","Userstrings","72522.htm"); +Page[36]=new Array("The Keithley Instruments 2601B-PULSE System SourceMeter® instrument is shipped with one or more factory scripts saved in its flash firmware memory. A factory script is made up of a number of functions. Some of them can be called from the front‑panel LOAD TEST menu. All of them can be called using remote programming.","As Keithley Instruments develops additional factory scripts, they will be made available on tek.com/keithley as a flash firmware upgrade for the 2601B-PULSE. See Upgrading the firmware for instructions on upgrading the flash firmware of your 2601B-PULSE instrument.","A factory script is similar to a user script, except a factory script is created by Keithley Instruments at the factory and is permanently stored in nonvolatile memory. The differences between a user script and a factory script include the following:","A factory script cannot be deleted from nonvolatile memory.","The script listing for a factory script can be retrieved and modified, but it is then treated as a user script. A user script cannot be saved as a factory script.","Factory scripts are not stored in global variables. The only references to factory scripts are in the script.factory.scripts attribute.","The script.factory.catalog() function returns an iterator that can be used in a for loop to iterate over all the factory scripts.","Example","To retrieve the catalog listing for factory scripts, send:","for name in script.factory.catalog() do print(name) end","Factory scripts","12911.htm"); +Page[37]=new Array("Use either of the following commands to run a factory script:","script.factory.scripts.name()
script.factory.scripts.name.run()","Where: name is the name of the factory script.","Example:","Run the factory script named KISweep.","script.factory.scripts.KISweep()","Running a factory script","12913.htm"); +Page[38]=new Array("Press the LOAD key.","Select FACTORY.","Select the function to run and press the ENTER key or navigation wheel @.","Press the RUN key.","Follow the prompts on the front panel to run the script.","Running a factory script function from the front-panel controls","12914.htm"); +Page[39]=new Array("The script listing for a factory script can be retrieved and modified. However, it cannot be saved as a factory script. The modified script can be saved as a user script using the same name or a new name.","An imported factory script can only be loaded back into the 2601B-PULSE as a user script.","The following function retrieves a script listing. The script code is output with the shell keywords (loadscript or loadandrunscript and endscript):","script.factory.scripts.name.list()","Where: name is the name of the factory script.","An example that retrieves the script listing for a factory script named KISweep:","script.factory.scripts.KISweep.list()","Retrieving and modifying a factory script listing","12194.htm"); +Page[40]=new Array("The KISweep factory script provides simple sweep test programming and shows how to use the sweeping function.","This script is made up of the following functions. Access these functions from the front panel or the remote interfaces. The following functions make up the KISweep factory script:","SweepILinMeasureV()","SweepIListMeasureV()","SweepILogMeasureV()","SweepVLinMeasureI()","SweepVListMeasureI()","SweepVLogMeasureI()","KISweep factory script","12175.htm"); +Page[41]=new Array("The KIHighC factory script is made up of two functions: i_leakage_measure() and i_leakage_threshold(). These functions are intended to be used when high capacitance mode is active. Output is generally at a non-zero voltage before calling these functions. These functions can also be used to step the voltage to zero volts in order to measure the leakage current.","i_leakage_measure()","i_leakage_threshold()","KIHighC factory script","12950.htm"); +Page[42]=new Array("The KIParlib factory script is made up of two functions: gm_vsweep() and gm_isweep().","gm_vsweep()","gm_isweep()","KIParlib factory script","12954.htm"); +Page[43]=new Array("The KISavebuffer script has one function: savebuffer().","savebuffer()","KISavebuffer factory script","12958.htm"); +Page[44]=new Array("This section contains general information about using TSP commands.","TSP command programming notes","19536.htm"); +Page[45]=new Array("This manual uses italicized text to represent the parts of remote commands that must be replaced by user specified values. The following examples show typical uses of italicized text: ","Example 1:","beeper.enable = state","Where state can be a value (beeper.ON or beeper.OFF) or an integer (1 or 0) that you specify. For example, to set this attribute on, you would send one of the following commands:","beeper.enable = beeper.ON","beeper.enable = 1","Example 2:","digio.trigger[N].assert()","Where N is an integer (1 to 14) that you specify. For example, to assert trigger line 7 you would send:","digio.trigger[7].assert()","To assert a trigger line with a variable as the integer, you would send:","triggerline = 7","digio.trigger[triggerline].assert()","Example 3:","smua.trigger.measure.Y(rbuffer)","Where: ","Y is the measurement type that you specify (v, i, r, or p). ","rbuffer is the reading buffer object where the readings will be stored. ","For example, to make voltage measurements and store them in buffer vbuffername, you would send:","smua.trigger.measure.v(vbuffername)","Placeholder text","92460.htm"); +Page[46]=new Array("Use these syntax requirements to build well-formed instrument control commands.","Instrument commands are case sensitive. Refer to the command reference descriptions for the correct case.","The white space in lists of parameters in functions is optional. For example, the following functions are equivalent:","digio.writebit(3,0)","digio.writebit (3, 0)"," All functions must have a set of parentheses () immediately following the function, even if there are no parameters specified. For example:","waitcomplete(G)","timezone = localnode.gettimezone()","If there are multiple parameters, they must be separated by commas (,). For example:","beeper.beep(0.5, 2400)","Syntax rules","17860.htm"); +Page[47]=new Array("Time and date values are represented as the number of seconds since some base. Representing time as a number of seconds is referred to as “standard time format.” There are three time bases:","UTC 12:00 am Jan 1, 1970. Some examples of UTC time are reading buffer base timestamps, adjustment dates, and the value returned by os.time().","Instrument on. References time to when the instrument was turned on. The value returned by os.clock() is referenced to the turn-on time.","Event. Time referenced to an event, such as the first reading stored in a reading buffer.","Time and date values","12044.htm"); +Page[48]=new Array("The following source-measure unit (SMU) settings are ignored when the pulser is enabled:","display.smua.limit.func","smua.measure.autorangeY","smua.measure.autozero","smua.measure.delay","smua.measure.highcrangedelayfactor","smua.measure.lowrangeY","smua.measure.nplc","smua.measure.rangeY","smua.sense","smua.source.autorangeY","smua.source.delay","smua.source.func","smua.source.highc","smua.source.limitY","smua.source.lowrangeY","smua.source.offlimitY","smua.source.rangeY","smua.source.settling","smua.source.sink","smua.trigger.endpulse.action","smua.trigger.endsweep.action","Settings ignored when the pulser is enabled","91979.htm"); +Page[49]=new Array("The following pulser settings do not affect source-measure unit (SMU) operation when the pulser is disabled:","smua.pulser.measure.aperture","smua.pulser.measure.delay","smua.pulser.protect.sensev","smua.pulser.protect.sourcev","smua.pulser.rangeY","Settings ignored when the pulser is disabled","91702.htm"); +Page[50]=new Array("The Test Script Processor (TSP®) command reference contains detailed descriptions of each of the TSP commands that you can use to control your instrument. Each command description is broken into subsections. The figure below shows an example of a command description.","The subsections contain information about the command. The subsections are:","Command name and summary table","Usage","Details","Example","Also see","The content of each of these subsections is described in the following topics.","Using the TSP command reference","17852.htm"); +Page[51]=new Array("Each instrument command description starts with the command name, followed by a brief description and a table with relevant information for each command. Definitions for the numbered items in the figure below are listed following the figure.","Instrument command name. Indicates the beginning of the command description. It is followed by a brief description of what the command does.","Type of command. Commands can be functions, attributes, or constants. If the command is an attribute, it can be read-only (R), read-write (RW), or write-only (W). For detail on commands, see Introduction to TSP operation.","TSP-Link accessible. Yes or No; indicates whether or not the command can be accessed through a TSP-Link network.","Affected by. Commands or actions that may change the setting of this command.","LAN restore defaults: This command is reset to the default value when lan.restoredefaults() is sent.","Digital I/O trigger N reset: This command is reset to the default value when digio.trigger[N].reset() is sent.","Recall setup: This command is stored as part of the saved setup and is changed to the value stored in the saved setup when the setup is recalled.","Instrument reset: This command is reset to the default value when reset(), localnode.reset(), or *RST is sent.","SMU reset: This command is reset to the default value when smua.reset() is sent.","Power cycle: This command is set to the default value when the instrument power is cycled.","Where saved. Indicates where the command settings reside once they are used on an instrument. Options include:","Not saved: Command is not saved anywhere and must be typed each time you use it.","Nonvolatile memory: Storage area in the instrument where information is saved when the instrument is turned off.","Saved setup: Command is saved as part of the saved setup.","Default value: Lists the default value or constant for the command. The parameter values are defined in the Usage or Details sections of the command description.","Command name and summary table","17853.htm"); +Page[52]=new Array("The Usage section of the remote command listing shows how to properly structure the command. Each line in the Usage section is a separate variation of the command usage. All possible command usage options are shown.","1 Structure of command usage: Shows how the parts of the command should be organized. If a parameter is shown to the left of the command, it is the return when you print the command. Information to the right is the parameters or other items you need to enter when setting the command.","2 User-supplied parameters: Indicated by italics. For example, for the function beeper.beep(duration, frequency), replace duration with the number of seconds and frequency with the frequency of the tone. Send beeper.beep(2, 2400) to generate a two-second, 2400 Hz tone.

Some commands have optional parameters. If there are optional parameters, they must be entered in the order presented in the Usage section. You cannot leave out any parameters that precede the optional parameter. Optional parameters are shown as separate lines in usage, presented in the required order with each valid permutation of the optional parameters.
For example:
printbuffer(startIndex, endIndex, buffer1)
printbuffer(startIndex, endIndex, buffer1, buffer2)","3 Parameter value options: Descriptions of the options that are available for the user-defined parameter.","Command usage","17854.htm"); +Page[53]=new Array("This section lists additional information you need to know to successfully use the remote command.","Command details","17855.htm"); +Page[54]=new Array("The Example section of the remote command description shows examples of how you can use the command.","1 Actual example code that you can copy from this table and paste into your own programming application.","2 Description of the code and what it does. This may also contain example output of the code.","Example section","17856.htm"); +Page[55]=new Array("The Also see section of the remote command description lists additional commands or sections that are related to the command.","Related commands and information","17857.htm"); +Page[56]=new Array("The TSP commands available for the instrument are listed in alphabetic order.","TSP commands","19389.htm"); +Page[57]=new Array("This function generates an audible tone.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","beeper.beep(duration, frequency)","duration","The amount of time to play the tone (0.001 s to 100 s)","frequency","The frequency of the tone in Hertz (Hz)","Details","You can use the beeper of the 2601B-PULSE to provide an audible signal at a specified frequency and time duration. For example, you can use the beeper to signal the end of a lengthy sweep.","The beeper will not sound if it is disabled. It can be disabled or enabled with the beeper enable command, or through the front panel.","Example","beeper.enable = beeper.ON","beeper.beep(2, 2400)","Enables the beeper and generates a two‑second, 2400 Hz tone.","Also see","beeper.enable","beeper.beep()","18841.htm"); +Page[58]=new Array("This command allows you to turn the beeper on or off.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Recall setup
Instrument reset","Saved setup","1 (beeper.ON)","Usage","state = beeper.enable","beeper.enable = state","state","Disable the beeper: beeper.OFF or 0","Enable the beeper: beeper.ON or 1","Details","This command enables or disables the beeper. When enabled, a beep signals that a front‑panel key has been pressed. Disabling the beeper also disables front‑panel key clicks.","Example","beeper.enable = beeper.ON","beeper.beep(2, 2400)","Enables the beeper and generates a two‑second, 2400 Hz tone.","Also see","beeper.beep()","beeper.enable","14435.htm"); +Page[59]=new Array("This function performs a bitwise logical AND operation on two numbers.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.bitand(value1, value2)","result","Result of the logical AND operation","value1","Operand for the logical AND operation","value2","Operand for the logical AND operation","Details","Any fractional parts of value1 and value2 are truncated to form integers. The returned result is also an integer.","Example","testResult = bit.bitand(10, 9)","print(testResult)","Performs a logical AND operation on decimal 10 (binary 1010) with decimal 9 (binary 1001), which returns a value of decimal 8 (binary 1000).","Output:","8.00000e+00","Also see","Bit manipulation and logic operations","bit.bitor()","bit.bitxor()","bit.bitand()","14632.htm"); +Page[60]=new Array("This function performs a bitwise logical OR operation on two numbers.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.bitor(value1, value2)","result","Result of the logical OR operation","value1","Operand for the logical OR operation","value2","Operand for the logical OR operation","Details","Any fractional parts of value1 and value2 are truncated to make them integers. The returned result is also an integer.","Example","testResult = bit.bitor(10, 9)","print(testResult)","Performs a bitwise logical OR operation on decimal 10 (binary 1010) with decimal 9 (binary 1001), which returns a value of decimal 11 (binary 1011).","Output:","1.10000e+01","Also see","Bit manipulation and logic operations","bit.bitand()","bit.bitxor()","bit.bitor()","14634.htm"); +Page[61]=new Array("This function performs a bitwise logical XOR (exclusive OR) operation on two numbers.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.bitxor(value1, value2)","result","Result of the logical XOR operation","value1","Operand for the logical XOR operation","value2","Operand for the logical XOR operation","Details","Any fractional parts of value1 and value2 are truncated to make them integers. The returned result is also an integer.","Example","testResult = bit.bitxor(10, 9)","print(testResult)","Performs a logical XOR operation on decimal 10 (binary 1010) with decimal 9 (binary 1001), which returns a value of decimal 3 (binary 0011).","Output:","3.00000e+00","Also see","Bit manipulation and logic operations","bit.bitand()","bit.bitor()","bit.bitxor()","14635.htm"); +Page[62]=new Array("This function clears a bit at a specified index position.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.clear(value, index)","result","Result of the bit manipulation","value","Specified number","index","One‑based bit position within value to clear (1 to 32)","Details","Any fractional part of value is truncated to make it an integer. The returned result is also an integer.","The least significant bit of value is at index position 1; the most significant bit is at index position 32.","Example","testResult = bit.clear(15, 2)","print(testResult)","The binary equivalent of decimal 15 is 1111. If you clear the bit at index position 2, the returned decimal value is 13 (binary 1101).","Output:","1.30000e+01","Also see","Bit manipulation and logic operations","bit.get()","bit.set()","bit.test()","bit.toggle()","bit.clear()","14636.htm"); +Page[63]=new Array("This function retrieves the weighted value of a bit at a specified index position.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.get(value, index)","result","Result of the bit manipulation","value","Specified number","index","One‑based bit position within value to get (1 to 32)","Details","This function returns the value of the bit in value at index. This is the same as returning value with all other bits set to zero (0).","The least significant bit of value is at index position 1; the most significant bit is at index position 32.","If the indexed bit for the number is set to zero (0), the result will be zero (0).","Example","testResult = bit.get(10, 4)","print(testResult)","The binary equivalent of decimal 10 is 1010. If you get the bit at index position 4, the returned decimal value is 8.","Output:","8.00000e+00","Also see","Bit manipulation and logic operations","bit.clear()","bit.set()","bit.test()","bit.toggle()","bit.get()","14637.htm"); +Page[64]=new Array("This function returns a field of bits from the value starting at the specified index position.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.getfield(value, index, width)","result","Result of the bit manipulation","value","Specified number","index","One‑based bit position within value to get (1 to 32)","width","The number of bits to include in the field (1 to 32)","Details","A field of bits is a contiguous group of bits. This function retrieves a field of bits from value starting at index.","The index position is the least significant bit of the retrieved field. The number of bits to return is specified by width.","The least significant bit of value is at index position 1; the most significant bit is at index position 32.","Example","myResult = bit.getfield(13, 2, 3)","print(myResult)","The binary equivalent of decimal 13 is 1101. ","The field at index position 2 and width 3 consists of the binary bits 110. The returned value is decimal 6 (binary 110).","Output:","6.00000e+00","Also see","Bit manipulation and logic operations","bit.get()","bit.set()","bit.setfield()","bit.getfield()","14638.htm"); +Page[65]=new Array("This function sets a bit at the specified index position.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.set(value, index)","result","Result of the bit manipulation","value","Specified number","index","One‑based bit position within value to set (1 to 32)","Details","This function returns result, which is value with the indexed bit set. The index must be between 1 and 32.","The least significant bit of value is at index position 1; the most significant bit is at index position 32.","Any fractional part of value is truncated to make it an integer.","Example","testResult = bit.set(8, 3)","print(testResult)","The binary equivalent of decimal 8 is 1000. If the bit at index position 3 is set to 1, the returned value is decimal 12 (binary 1100).","Output:","1.20000e+01","Also see","Bit manipulation and logic operations","bit.clear()","bit.get()","bit.getfield()","bit.setfield()","bit.test()","bit.toggle()","bit.set()","14639.htm"); +Page[66]=new Array("This function overwrites a bit field at a specified index position.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.setfield(value, index, width, fieldValue)","result","Result of the bit manipulation","value","Specified number","index","One‑based bit position in value to set (1 to 32)","width","The number of bits to include in the field (1 to 32)","fieldValue","Value to write to the field","Details","This function returns result, which is value with a field of bits overwritten, starting at index. The index specifies the position of the least significant bit of value. The width bits starting at index are set to fieldValue.","The least significant bit of value is at index position 1; the most significant bit is at index position 32.","Before setting the field of bits, any fractional parts of value and fieldValue are truncated to form integers.","If fieldValue is wider than width, the most significant bits of the fieldValue that exceed the width are truncated. For example, if width is 4 bits and the binary value for fieldValue is 11110 (5 bits), the most significant bit of fieldValue is truncated and a binary value of 1110 is used.","Example","testResult = bit.setfield(15, 2, 3, 5)","print(testResult)","The binary equivalent of decimal 15 is 1111. After overwriting it with a decimal 5 (binary 101) at index position 2, the returned value is decimal 11 (binary 1011).","Output:","1.10000e+01","Also see","Bit manipulation and logic operations","bit.get()","bit.set()","bit.getfield()","bit.setfield()","14640.htm"); +Page[67]=new Array("This function returns the Boolean value (true or false) of a bit at the specified index position.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.test(value, index)","result","Result of the bit manipulation","value","Specified number","index","One‑based bit position within value to test (1 to 32)","Details","This function returns result, which is the result of the tested bit. ","The least significant bit of value is at index position 1; the most significant bit is at index position 32.","If the indexed bit for value is 0, result is false. If the bit of value at index is 1, the returned value is true.","If index is bigger than the number of bits in value, the result is false.","Example","testResult = bit.test(10, 4)","print(testResult)","The binary equivalent of decimal 10 is 1010. Testing the bit at index position 4 returns a Boolean value of true.","Output:","true","Also see","Bit manipulation and logic operations","bit.clear()","bit.get()","bit.set()","bit.toggle()","bit.test()","14641.htm"); +Page[68]=new Array("This function toggles the value of a bit at a specified index position.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","result = bit.toggle(value, index)","result","Result of the bit manipulation","value","Specified number","index","One‑based bit position within value to toggle (1 to 32)","Details","This function returns result, which is the result of toggling the bit index in value.","Any fractional part of value is truncated to make it an integer. The returned value is also an integer.","The least significant bit of value is at index position 1; the most significant bit is at index position 32.","The indexed bit for value is toggled from 0 to 1, or 1 to 0.","Example","testResult = bit.toggle(10, 3)","print(testResult)","The binary equivalent of decimal 10 is 1010. Toggling the bit at index position 3 returns a decimal value of 14 (binary 1110).","Output:","1.40000e+01","Also see","Bit manipulation and logic operations","bit.clear()","bit.get()","bit.set()","bit.test()","bit.toggle()","14642.htm"); +Page[69]=new Array("This attribute sets the state of the reading buffer's append mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","See Details","0 (disabled)","Usage","state = bufferVar.appendmode","bufferVar.appendmode = state","state","The reading buffer append mode; set to one of the following:","0: Append mode off; new measurement data overwrites the previous buffer content","1: Append mode on; appends new measurement data to the present buffer content","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","Assigning a value to this attribute enables or disables the buffer append mode. This value can only be changed with an empty buffer. Use bufferVar.clear() to empty the buffer.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","If the append mode is set to 0, any stored readings in the buffer are cleared before new ones are stored. If append mode is set to 1, any stored readings remain in the buffer and new readings are added to the buffer after the stored readings.","With append mode on, the first new measurement is stored at rb[n+1], where n is the number of readings stored in buffer rb.","Example","buffer1.appendmode = 1","Append new readings to contents of the reading buffer named buffer1.","Also see","bufferVar.clear()","Reading buffers","bufferVar.appendmode","15127.htm"); +Page[70]=new Array("This attribute contains the timestamp that indicates when the first reading was stored in the buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","See Details","0","Usage","basetime = bufferVar.basetimestamp","basetime","The timestamp of the first stored reading","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","Details","This read-only attribute contains the timestamp (in seconds) of the first reading stored in a buffer (rb[1] stored in reading buffer rb). The timestamp is the number of seconds since 12:00 am January 1, 1970 (UTC) that the measurement was performed and stored.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","See the smua.nvbufferY attribute for details on accessing dedicated reading buffers.","Example","basetime = smua.nvbuffer1.basetimestamp","print(basetime)","Read the timestamp for the first reading","stored in dedicated reading buffer 1.","Output:","1.57020e+09","This output indicates that the timestamp is 1,570,200,000 seconds (which is Friday, October, 4, 2019 at 14:40:00 pm).","Also see","Reading buffers","smua.measure.overlappedY()","smua.measure.Y()","smua.nvbufferY","smua.trigger.measure.Y()","bufferVar.basetimestamp","15128.htm"); +Page[71]=new Array("This attribute enables or disables the reading buffer cache (on or off).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Not saved","1 (enabled)","Usage","cacheMode = bufferVar.cachemode","bufferVar.cachemode = cacheMode","cacheMode","The reading buffer cache mode; set to one of the following:","0: Cache mode disabled (off)","1: Cache mode enabled (on)","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","Assigning a value to this attribute enables or disables the reading buffer cache. When enabled, the reading buffer cache improves access speed to reading buffer data. ","If you run successive operations that overwrite reading buffer data, the reading buffer may return stale cache data. This can happen when initiating successive sweeps without reconfiguring the sweep measurements or when overwriting data in the reading buffer by setting the bufferVar.fillmode attribute to smua.FILL_WINDOW. To avoid this, make sure that you include commands that automatically invalidate the cache as needed (for example, explicit calls to the bufferVar.clearcache() function) or disable the cache using this attribute (bufferVar.cachemode).","Example","smua.nvbuffer1.cachemode = 1","Enables reading buffer cache of dedicated reading buffer 1 (source‑measure unit (SMU) channel A).","Also see","bufferVar.clearcache()","bufferVar.fillmode","Reading buffers","bufferVar.cachemode","17109.htm"); +Page[72]=new Array("This attribute sets the number of readings a buffer can store.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","See Details","Not applicable","Usage","bufferCapacity = bufferVar.capacity","bufferCapacity","The maximum number of readings the buffer can store","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","This read-only attribute reads the number of readings that can be stored in the buffer.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","The capacity of the buffer does not change as readings fill the buffer. A dedicated reading buffer that only collects basic items can store over 140,000 readings. Turning on additional collection items, such as timestamps and source values, decreases the capacity of a dedicated reading buffer (for example, smua.nvbuffer1), but does not change the capacity of a user-defined dynamically allocated buffer. A user-defined dynamically allocated buffer has a fixed capacity that is set when the buffer is created.","See the smua.nvbufferY attribute for details on accessing dedicated reading buffers. See the smua.makebuffer() function for information on creating user-defined dynamically allocated reading buffers.","Example","bufferCapacity = smua.nvbuffer1.capacity","print(bufferCapacity)","Reads the capacity of dedicated reading
buffer 1 (source‑measure unit (SMU) channel A).","Output:","1.49789e+05","The above output indicates that the buffer can hold 149789 readings.","Also see","Reading buffers","smua.makebuffer()","smua.measure.overlappedY()","smua.measure.Y()","smua.nvbufferY","smua.trigger.measure.Y()","bufferVar.capacity","15129.htm"); +Page[73]=new Array("This function empties the buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","bufferVar.clear()","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","This function clears all readings and related recall attributes from the buffer (for example, bufferVar.timestamps and bufferVar.statuses) from the specified buffer.","Example","smua.nvbuffer1.clear()","Clears dedicated reading buffer 1 (source‑measure unit (SMU) channel A).","Also see","Reading buffers","smua.nvbufferY","bufferVar.clear()","15130.htm"); +Page[74]=new Array("This function clears the cache.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","bufferVar.clearcache()","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","This function clears all readings from the specified cache. ","If you run successive operations that overwrite reading buffer data, the reading buffer may return stale cache data. This can happen when you:","Initiate successive sweeps without reconfiguring the sweep measurements. Watch for this when running Lua code remotely on more than one node, because values in the reading buffer cache may change while the Lua code is running.","Overwrite data in the reading buffer by setting the bufferVar.fillmode attribute to smua.FILL_WINDOW.","To avoid this, you can include explicit calls to the bufferVar.clearcache() function to remove stale values from the reading buffer cache.","Example","smua.nvbuffer1.clearcache()","Clears the reading buffer cache for dedicated reading buffer 1.","Also see","bufferVar.fillmode","Reading buffers","Removing stale values from the reading buffer cache","smua.nvbufferY","bufferVar.clearcache()","15131.htm"); +Page[75]=new Array("This attribute sets whether or not source values are stored with the readings in the buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","See Details","0 (disabled)","Usage","state = bufferVar.collectsourcevalues","bufferVar.collectsourcevalues = state","state","Source value collection status; set to one of the following:","0: Source value collection disabled (off)","1: Source value collection enabled (on)","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","Details","Assigning a value to this attribute enables or disables the storage of source values. Reading this attribute returns the state of source value collection. This value can only be changed with an empty buffer. Empty the buffer using the bufferVar.clear() function.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","When on, source values are stored with readings in the buffer. This requires four extra bytes of storage for each reading. Turning on additional collection items, such as source values (this attribute) and timestamps, decreases the capacity of a dedicated reading buffer, but does not change the capacity of a user-defined dynamically allocated buffer.","You cannot collect source values when smua.trigger.measure.action is set to smua.ASYNC, so this must be set to 0 when the measurement action is set to be asynchronous.","Example","smua.nvbuffer1.collectsourcevalues = 1","Include source values with readings for dedicated reading buffer 1.","Also see","bufferVar.clear()","Reading buffers","smua.measure.overlappedY()","smua.measure.Y()","smua.nvbufferY","smua.trigger.measure.action","smua.trigger.measure.Y()","bufferVar.collectsourcevalues","15132.htm"); +Page[76]=new Array("This attribute sets whether or not timestamp values are stored with the readings in the buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","See Details","0 (disabled)","Usage","state = bufferVar.collecttimestamps","bufferVar.collecttimestamps = state","state","Timestamp value collection status; set to one of the following:","0: Timestamp value collection disabled (off)","1: Timestamp value collection enabled (on)","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","Assigning a value to this attribute enables or disables the storage of timestamps. Reading this attribute returns the state of timestamp collection. ","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","When on, timestamp values are stored with readings in the buffer. This requires four extra bytes of storage for each reading. Turning on additional collection items, such as timestamps (this attribute) and source values, decreases the capacity of a dedicated reading buffer (for example, smua.nvbuffer1), but does not change the capacity of a user-defined dynamically allocated buffer.","This value, off (0) or on (1), can only be changed when the buffer is empty. Empty the buffer using the bufferVar.clear() function.","Example","smua.nvbuffer1.collecttimestamps = 1","Include timestamps with readings for dedicated reading buffer 1.","Also see","bufferVar.clear()","Reading buffers","smua.measure.overlappedY()","smua.measure.Y()","smua.nvbufferY","smua.trigger.measure.Y()","bufferVar.collecttimestamps","15133.htm"); +Page[77]=new Array("This attribute sets the reading buffer fill count.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","See Details","0","Usage","fillCount = bufferVar.fillcount","bufferVar.fillcount = fillCount","fillCount","The reading buffer fill count","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","Details","The reading buffer fill count sets the number of readings to store before restarting at index 1. If the value is zero (0), then the capacity of the buffer is used. Use this attribute to control when the SMU restarts filling the buffer at index 1, rather than having it restart when the buffer is full. ","If the bufferVar.fillcount attribute is set to a value higher than the capacity of the buffer, after storing the element at the end of the buffer, the SMU will overwrite the reading at index 1, the reading after that will overwrite the reading at index 2, and so on.","This attribute is only used when the bufferVar.fillmode attribute is set to smua.FILL_WINDOW.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example","smua.nvbuffer1.fillcount = 50","Sets fill count of dedicated reading buffer 1 to 50.","Also see","bufferVar.fillmode","bufferVar.fillcount","18551.htm"); +Page[78]=new Array("This attribute sets the reading buffer fill mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","See Details","0 (smua.FILL_ONCE)","Usage","fillMode = bufferVar.fillmode","bufferVar.fillmode = fillMode","fillMode","The reading buffer fill mode; set to one of the following:","0 or smua.FILL_ONCE: Do not overwrite old data","1 or smua.FILL_WINDOW: New readings restart at index 1 after acquiring reading at index bufferVar.fillcount","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","Details","When this attribute is set to smua.FILL_ONCE, the reading buffer will not overwrite readings. If the buffer fills up, new readings will be discarded. ","When this attribute is set to smua.FILL_WINDOW, new readings will be added after existing data until the buffer holds bufferVar.fillcount elements. Continuing the sequence, the next reading will overwrite the reading at index 1, the reading after that will overwrite the reading at index 2, and so on. ","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example","smua.nvbuffer1.fillmode = smua.FILL_ONCE","Sets fill mode of dedicated reading buffer 1 to fill once (do not overwrite old data).","Also see","bufferVar.fillcount","Reading buffers","bufferVar.fillmode","18552.htm"); +Page[79]=new Array("This attribute contains the measurement function that was used to acquire a reading stored in a specified reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","measurefunction = bufferVar.measurefunctions[N]","measurefunction","The measurement function used (Current, Voltage, Ohms, or Watts) to acquire reading number N in the specified buffer","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","N","The reading number (1 to bufferVar.n)","Details","The measurefunctions buffer recall attribute is like an array (a Lua table) of strings indicating the function measured for the reading.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example 1","measurefunction = smua.nvbuffer1.measurefunctions[5]","Store the measure function used to make reading number 5.","Example 2","printbuffer(1, 5, smua.nvbuffer1.measurefunctions)","Print the measurement function that was used to measure the first five readings saved in dedicated reading buffer 1.","Example output:","Current, Current, Current, Current, Current","Also see","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestamps","Reading buffers","bufferVar.measurefunctions","19914.htm"); +Page[80]=new Array("This attribute contains the measurement range values that were used for readings stored in a specified buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","measurerange = bufferVar.measureranges[N]","measurerange","The measurement range used to acquire reading number N in the specified buffer","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","N","The reading number (1 to bufferVar.n)","Details","The measureranges buffer recall attribute is like an array (a Lua table) of full-scale range values for the measure range used when the measurement was made.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example 1","measurerange = smua.nvbuffer1.measureranges[1]","Store the measure range that was used to make reading number 1.","Example 2","printbuffer(1, 10, smua.nvbuffer1.measureranges)","Print the range values that were used for the first 10 readings saved in dedicated reading buffer 1.","Example output:","1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07,
1.00000e-07, 1.00000e-07","Also see","bufferVar.measurefunctions","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestamps","Reading buffers","bufferVar.measureranges","19915.htm"); +Page[81]=new Array("This attribute contains the number of readings in the buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","numberOfReadings = bufferVar.n","numberOfReadings","The number of readings stored in the buffer","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","This read-only attribute contains the number of readings presently stored in the buffer.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example","numberOfReadings = smua.nvbuffer1.n","print(numberOfReadings)","Reads the number of readings stored in dedicated reading buffer 1 (source‑measure unit (SMU) channel A).","Output:","1.25000+02","The above output indicates that there are 125 readings stored in the buffer.","Also see","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestamps","Reading buffers","smua.measure.overlappedY()","smua.measure.Y()","smua.nvbufferY","smua.trigger.measure.Y()","bufferVar.n","15134.htm"); +Page[82]=new Array("This attribute contains the readings stored in a specified reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","reading = bufferVar.readings[N]","reading","The value of the reading in the specified reading buffer","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","N","The reading number N; can be any value from 1 to the number of readings in the buffer; use the bufferVar.n command to determine the number of readings in the buffer","Details","The readings buffer recall attribute is like an array (a Lua table) of the readings stored in the reading buffer. This array holds the same data that is returned when the reading buffer is accessed directly; that is, rb[2] and rb.readings[2] access the same value.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example","print(smua.nvbuffer1.readings[1])","Output the first reading saved in source‑measure unit (SMU) channel A, dedicated reading buffer 1.","Output:","8.81658e-08","Also see","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestamps","Reading buffers","bufferVar.readings","19920.htm"); +Page[83]=new Array("This attribute contains the source function that was being used when the readings were stored in a specified reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","sourcefunction = bufferVar.sourcefunctions[N]","sourcefunction","The source function used (Current or Voltage) to acquire reading number N in the specified buffer","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","N","The reading number (1 to bufferVar.n)","Details","The sourcefunctions buffer recall attribute is like an array (a Lua table) of strings indicating the source function at the time of the measurement.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example 1","sourcefunction = smua.nvbuffer1.sourcefunctions[3]","print(sourcefunction)","Store the source function used to make reading number 3 and output the value.","Example 2","printbuffer(1, 10, smua.nvbuffer1.sourcefunctions)","Print the source function used for 10 readings stored in dedicated reading buffer 1.","Example output:","Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage, Voltage","Also see","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestamps","Reading buffers","bufferVar.sourcefunctions","19916.htm"); +Page[84]=new Array("This attribute indicates the state of the source output for readings that are stored in a specified buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","state = bufferVar.sourceoutputstates[N]","state","The output state (Off or On) when reading N of the specified buffer was acquired","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","N","The reading number (1 to bufferVar.n)","Details","The sourceoutputstates buffer recall attribute is similar to an array (a Lua table) of strings. This array indicates the state of the source output (Off or On) at the time of the measurement.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example","printbuffer(1, 1, smua.nvbuffer1.sourceoutputstates)","Print the source output for the first reading stored in dedicated reading buffer 1.","Example output:","On","Also see","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestamps","Reading buffers","bufferVar.sourceoutputstates","19917.htm"); +Page[85]=new Array("This attribute contains the source range that was used for readings stored in a specified reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","sourcerange = bufferVar.sourceranges[N]","sourcerange","The source range used to acquire reading number N in the specified buffer","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","N","The reading number (1 to bufferVar.n)","Details","The sourceranges buffer recall attribute is like an array (a Lua table) of full-scale range values for the source range used when the measurement was made.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example 1","sourcerange = smua.nvbuffer1.sourceranges[1]","Store the source range that was used for the first reading stored in dedicated reading buffer 1.","Example 2","printbuffer(1, 6, smua.nvbuffer1.sourceranges)","Print the source ranges that were used for the first 6 readings stored in source‑measure unit (SMU) A, buffer 1.","Example output:","1.00000e-04, 1.00000e-04, 1.00000e-04, 1.00000e-04, 1.00000e-04, 1.00000e-04","Also see","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourcevalues","bufferVar.statuses","bufferVar.timestamps","Reading buffers","bufferVar.sourceranges","19918.htm"); +Page[86]=new Array("When enabled by the bufferVar.collectsourcevalues attribute, this attribute contains the source levels being output when readings in the reading buffer were acquired.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","sourcevalue = bufferVar.sourcevalues[N]","sourcevalue","The output value of the source when reading N of the specified buffer was acquired","bufferVar","The reading buffer; can be a dynamically allocated buffer (user‑defined), or a dedicated reading buffer (such as smua.nvbuffer1)","N","The reading number (1 to bufferVar.n)","Details","If the bufferVar.collectsourcevalues attribute is enabled before readings are taken, the bufferVar.sourcevalues buffer recall attribute is like an array (a Lua table) of the sourced value in effect at the time of the reading. Note that you can set the bufferVar.collectsourcevalues attribute only if the affected reading buffer is empty. See bufferVar.collectsourcevalues for more detailed information.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example 1","sourcevalue = smua.nvbuffer1.sourcevalues[1]","Get the sourced value of the first reading stored in dedicated reading buffer 1.","Example 2","printbuffer(1, 6, smua.nvbuffer1.sourcevalues)","Print the sourced value of the first 6 readings stored in source‑measure unit (SMU) A, buffer 1.","Example output:","1.00000e-04, 1.00000e-04,","1.00000e-04, 1.00000e-04,","1.00000e-04, 1.00000e-04","Also see","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.statuses","bufferVar.timestamps","Reading buffers","bufferVar.sourcevalues","19919.htm"); +Page[87]=new Array("This attribute contains the status values of readings in the reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","statusInformation = bufferVar.statuses[N]","statusInformation","The status value when reading N of the specified buffer was acquired","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","N","The reading number N; can be any value from 1 to the number of readings in the buffer; use the bufferVar.n command to determine the number of readings in the buffer","Details","This read‑only buffer recall attribute is like an array (a Lua table) of the status values for all the readings in the buffer. The status values are floating-point numbers that encode the status value; see the following table for values. ","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Buffer status bits","Bit","Name","Hex","Description when bit is true","B0","Pulser","0x01","Pulser is enabled","B1","Overtemp","0x02","Overtemperature condition","B2","AutoRangeMeas","0x04","Measure range was autoranged","B3","AutoRangeSrc","0x08","Source range was autoranged","B4","4Wire","0x10","4-wire (remote) sense mode enabled","B5","Rel","0x20","Relative offset applied to reading","B6","Compliance","0x40","Source function was limited because the complementary function would be over the compliance limit","B7","Filtered","0x80","Reading was filtered","Example","reset() ","smua.source.func = smua.OUTPUT_DCVOLTS","smua.source.autorangev = smua.AUTORANGE_ON","smua.source.levelv = 5 ","smua.source.limiti = 10e-3","smua.measure.rangei = 10e-3","smua.source.output = smua.OUTPUT_ON","print(smua.measure.i(smua.nvbuffer1))","smua.source.output = smua.OUTPUT_OFF","print(smua.nvbuffer1.statuses[1])","Reset the instrument.","Set the voltage source function to DC volts. Set the range to auto.","Set the voltage source to 5 V.","Set current measure limit to 10 mA.","Set the current measure range to 10 mA.","Turn on the output.","Print and place the current reading in the reading buffer.","Turn off the output.","Output status value of the first measurement in the reading buffer. ","Output example:","3.99470e-06","4.00000e+00","Also see","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.timestamps","Reading buffers","bufferVar.statuses","92702.htm"); +Page[88]=new Array("This attribute contains the resolution of the timestamp.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","See Details","1e-6 (1 µs)","Usage","resolution = bufferVar.timestampresolution","resolution","Timestamp resolution in seconds","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","Details","Assigning a value to this attribute sets the resolution for the timestamps. Reading this attribute returns the timestamp resolution value. This value can only be changed with an empty buffer. Empty the buffer using the bufferVar.clear() function.","The finest timestamp resolution is 0.000001 seconds (1 μs). At this resolution, the reading buffer can store unique timestamps for up to 71 minutes. This value can be increased for very long tests.","The value specified when setting this attribute will be rounded to an even power of 2 µs.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example","smua.nvbuffer1.timestampresolution = 0.000008","Sets the timestamp resolution of dedicated reading buffer 1 to 8 μs.","Also see","bufferVar.clear()","bufferVar.collecttimestamps","bufferVar.timestamps","Reading buffers","smua.measure.overlappedY()","smua.measure.Y()","smua.nvbufferY","smua.trigger.measure.Y()","bufferVar.timestampresolution","15135.htm"); +Page[89]=new Array("When enabled by the bufferVar.collecttimestamps attribute, this attribute contains the timestamp when each reading saved in the specified reading buffer occurred.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Clearing the buffer","See Details","Not applicable","Usage","timestamp = bufferVar.timestamps[N]","timestamp","The complete timestamp (including date, time, and fractional seconds) of reading number N in the specified reading buffer when the reading was acquired","bufferVar","The reading buffer; can be a dynamically allocated user-defined buffer or a dedicated reading buffer","N","The reading number (1 to bufferVar.n)","Details","The bufferVar.timestamps information from a reading buffer is only available if the bufferVar.collecttimestamps attribute is set to 1 (default setting). If it is set to 0, you cannot access any time information from a reading buffer. ","If enabled, this buffer recall attribute is like an array (a Lua table) that contains timestamps, in seconds, of when each reading occurred. These are relative to the bufferVar.basetimestamp for the buffer.","For dedicated reading buffers, all buffer attributes are saved to nonvolatile memory only when the reading buffer is saved to nonvolatile memory.","Example","timestamp = smua.nvbuffer1.timestamps[1]","Get the timestamp of the first reading stored in source‑measure unit (SMU) A, buffer 1.","Also see","bufferVar.clear()","bufferVar.collecttimestamps","bufferVar.measurefunctions","bufferVar.measureranges","bufferVar.n","bufferVar.readings","bufferVar.sourcefunctions","bufferVar.sourceoutputstates","bufferVar.sourceranges","bufferVar.sourcevalues","bufferVar.statuses","Reading buffers","bufferVar.timestamps","19922.htm"); +Page[90]=new Array("This function adds an entry to the data queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","result = dataqueue.add(value)","result = dataqueue.add(value, timeout)","result","The resulting value of true or false based on the success of the function","value","The data item to add; value can be of any type","timeout","The maximum number of seconds to wait for space in the data queue","Details","You cannot use the timeout value when accessing the data queue from a remote node (you can only use the timeout value while adding data to the local data queue).","The timeout value is ignored if the data queue is not full.","The dataqueue.add() function returns false:","If the timeout expires before space is available in the data queue","If the data queue is full and a timeout value is not specified","If the value is a table, a duplicate of the table and any subtables is made. The duplicate table does not contain any references to the original table or to any subtables.","Example","dataqueue.clear()","dataqueue.add(10)","dataqueue.add(11, 2)","result = dataqueue.add(12, 3)","if result == false then"," print("Failed to add 12 to the dataqueue")","end","print("The dataqueue contains:")","while dataqueue.count > 0 do"," print(dataqueue.next())","end","Clear the data queue.","Each line adds one item to the data queue.","Output:","The dataqueue contains:","10","11","12","Also see","dataqueue.CAPACITY","dataqueue.clear()","dataqueue.count","dataqueue.next()","Using the data queue for real-time communication","dataqueue.add()","14654.htm"); +Page[91]=new Array("This constant is the maximum number of entries that you can store in the data queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","count = dataqueue.CAPACITY","count","The variable that is assigned the value of dataqueue.CAPACITY","Details","This constant always returns the maximum number of entries that can be stored in the data queue.","Example","MaxCount = dataqueue.CAPACITY","while dataqueue.count < MaxCount do"," dataqueue.add(1)","end","print("There are " .. dataqueue.count"," .. " items in the data queue")","This example fills the data queue until it is full and prints the number of items in the queue.","Output:","There are 128 items in the data queue","Also see","dataqueue.add()","dataqueue.clear()","dataqueue.count","dataqueue.next()","Using the data queue for real-time communication","dataqueue.CAPACITY","14656.htm"); +Page[92]=new Array("This function clears the data queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","dataqueue.clear()","Details","This function forces all dataqueue.add() commands that are in progress to time out and deletes all data from the data queue.","Example","MaxCount = dataqueue.CAPACITY","while dataqueue.count < MaxCount do"," dataqueue.add(1)","end","print("There are " .. dataqueue.count"," .. " items in the data queue")","dataqueue.clear()","print("There are " .. dataqueue.count"," .. " items in the data queue")","This example fills the data queue and prints the number of items in the queue. It then clears the queue and prints the number of items again.","Output:","There are 128 items in the data
queue","There are 0 items in the data queue","Also see","dataqueue.add()","dataqueue.CAPACITY","dataqueue.count","dataqueue.next()","Using the data queue for real-time communication","dataqueue.clear()","14655.htm"); +Page[93]=new Array("This attribute contains the number of items in the data queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","count = dataqueue.count","count","The number of items in the data queue","Details","The count is updated as entries are added with dataqueue.add() and read from the data queue with dataqueue.next(). It is also updated when the data queue is cleared with dataqueue.clear().","A maximum of dataqueue.CAPACITY items can be stored at any one time in the data queue.","Example","MaxCount = dataqueue.CAPACITY","while dataqueue.count < MaxCount do"," dataqueue.add(1)","end","print("There are " .. dataqueue.count"," .. " items in the data queue")","dataqueue.clear()","print("There are " .. dataqueue.count"," .. " items in the data queue")","This example fills the data queue and prints the number of items in the queue. It then clears the queue and prints the number of items again.","Output:","There are 128 items in the data queue","There are 0 items in the data queue","Also see","dataqueue.add()","dataqueue.CAPACITY","dataqueue.clear()","dataqueue.next()","Using the data queue for real-time communication","dataqueue.count","14657.htm"); +Page[94]=new Array("This function removes the next entry from the data queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","value = dataqueue.next()","value = dataqueue.next(timeout)","value","The next entry in the data queue","timeout","The number of seconds to wait for data in the queue","Details","If the data queue is empty, the function waits up to the timeout value.","If data is not available in the data queue before the timeout expires, the return value is nil.","The entries in the data queue are removed in first-in, first-out (FIFO) order.","If the value is a table, a duplicate of the original table and any subtables is made. The duplicate table does not contain any references to the original table or to any subtables.","Example","dataqueue.clear()","for i = 1, 10 do"," dataqueue.add(i)","end","print("There are " .. dataqueue.count"," .. " items in the data queue")","while dataqueue.count > 0 do"," x = dataqueue.next()"," print(x)","end","print("There are " .. dataqueue.count"," .. " items in the data queue")","Clears the data queue, adds ten entries, then reads the entries from the data queue. Note that your output may differ depending on the setting of format.asciiprecision.","Output:","There are 10 items in the data queue","1","2","3","4","5","6","7","8","9","10","There are 0 items in the data queue","Also see","dataqueue.add()","dataqueue.CAPACITY","dataqueue.clear()","dataqueue.count","format.asciiprecision","Using the data queue for real-time communication","dataqueue.next()","14658.htm"); +Page[95]=new Array("This function delays the execution of the commands that follow it.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","delay(seconds)","seconds","The number of seconds to delay (0 to 100 ks)","Details","The instrument delays execution of the commands for at least the specified number of seconds and fractional seconds. However, the processing time may cause the instrument to delay 5 μs to 10 μs (typical) more than the requested delay.","Example","beeper.beep(0.5, 2400)","delay(0.250)","beeper.beep(0.5, 2400)","Emit a double‑beep at 2400 Hz. The sequence is 0.5 s on, 0.25 s off, 0.5 s on.","Also see","None","delay()","13949.htm"); +Page[96]=new Array("This function reads one digital I/O line. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","data = digio.readbit(N)","data","The state of the I/O line","N","Digital I/O line number to be read (1 to 14)","Details","A returned value of zero (0) indicates that the line is low. A returned value of one (1) indicates that the line is high.","Example","print(digio.readbit(4))","Assume line 4 is set high, and it is then read.","Output:","1.00000e+00","Also see","digio.readport()","digio.writebit()","digio.writeport()","Digital I/O port","digio.readbit()","14668.htm"); +Page[97]=new Array("This function reads the digital I/O port. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","data = digio.readport()","data","The present value of the input lines on the digital I/O port","Details","The binary equivalent of the returned value indicates the value of the input lines on the I/O port. The least significant bit (bit B1) of the binary number corresponds to line 1; bit B14 corresponds to line 14.","For example, a returned value of 170 has a binary equivalent of 000000010101010, which indicates that lines 2, 4, 6, and 8 are high (1), and the other 10 lines are low (0).","Example","data = digio.readport()","print(data)","Assume lines 2, 4, 6, and 8 are set high when the I/O port is read.","Output:","1.70000e+02","This is binary 10101010","Also see","digio.readbit()","digio.writebit()","digio.writeport()","Digital I/O port","digio.readport()","14669.htm"); +Page[98]=new Array("This function asserts a trigger pulse on one of the digital I/O lines. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","digio.trigger[N].assert()","N","Digital I/O trigger line (1 to 14)","Details","The pulse width that is set determines how long the instrument asserts the trigger.","Example","digio.trigger[2].assert()","Asserts a trigger on digital I/O line 2.","Also see","digio.trigger[N].pulsewidth","digio.trigger[N].assert()","14670.htm"); +Page[99]=new Array("This function clears the trigger event on a digital I/O line. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","digio.trigger[N].clear()","N","Digital I/O trigger line (1 to 14)","Details","The event detector of a trigger enters the detected state when an event is detected. It is cleared when digio.trigger[N].wait() or digio.trigger[N].clear() is called.","digio.trigger[N].clear() clears the event detector of the specified trigger line, discards the history of the trigger line, and clears the digio.trigger[N].overrun attribute.","Example","digio.trigger[2].clear()","Clears the trigger event detector on I/O line 2.","Also see","digio.trigger[N].overrun","digio.trigger[N].wait()","digio.trigger[N].clear()","14671.htm"); +Page[100]=new Array("This constant identifies the trigger event generated by the digital I/O line N. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = digio.trigger[N].EVENT_ID","eventID","The trigger event number","N","Digital I/O trigger line (1 to 14)","Details","To have another trigger object respond to trigger events generated by the trigger line, set the stimulus attribute of the other object to the value of this constant.","Example","digio.trigger[5].stimulus = digio.trigger[3].EVENT_ID","Uses a trigger event on digital I/O trigger line 3 to be the stimulus for digital I/O trigger line 5.","Also see","None","digio.trigger[N].EVENT_ID","14672.htm"); +Page[101]=new Array("This attribute sets the mode in which the trigger event detector and the output trigger generator operate on the given trigger line. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Digital I/O trigger N reset
Recall setup","Not saved ","0 (digio.TRIG_BYPASS)","Usage","triggerMode = digio.trigger[N].mode","digio.trigger[N].mode = triggerMode","triggerMode","The trigger mode; see Details for values","N","Digital I/O trigger line (1 to 14)","Details","Set triggerMode to one of the following values:","Trigger mode values","triggerMode","Description","digio.TRIG_BYPASS or 0","Allows direct control of the line.","digio.TRIG_FALLING or 1","Detects falling‑edge triggers as input; asserts a TTL-low pulse for output.","digio.TRIG_RISING or 2","If the programmed state of the line is high, the digio.TRIG_RISING mode behavior is similar to digio.TRIG_RISINGA. If the programmed state of the line is low, the digio.TRIG_RISING mode behavior is similar to digio.TRIG_RISINGM. This setting should only be used if necessary for compatibility with other Keithley Instruments products.","digio.TRIG_EITHER or 3","Detects rising- or falling‑edge triggers as input. Asserts a TTL‑low pulse for output.","digio.TRIG_SYNCHRONOUSA or 4","Detects the falling‑edge input triggers and automatically latches and drives the trigger line low. Asserting the output trigger releases the latched line.","digio.TRIG_SYNCHRONOUS or 5","Detects the falling‑edge input triggers and automatically latches and drives the trigger line low. Asserts a TTL‑low pulse as an output trigger.","digio.TRIG_SYNCHRONOUSM or 6","Detects rising‑edge triggers as input. Asserts a TTL‑low pulse for output.","digio.TRIG_RISINGA or 7","Detects rising‑edge triggers as input. Asserts a TTL‑low pulse for output.","digio.TRIG_RISINGM or 8","Asserts a TTL-high pulse for output. Input edge detection is not possible in this mode.","When programmed to any mode except digio.TRIG_BYPASS, the output state of the I/O line is controlled by the trigger logic, and the user‑specified output state of the line is ignored.","Use of either digio.TRIG_SYNCHRONOUSA or digio.TRIG_SYNCHRONOUSM is preferred over digio.TRIG_SYNCHRONOUS, because digio.TRIG_SYNCHRONOUS is provided for compatibility with the digital I/O and TSP-Link triggering on older firmware.","To control the line state, set the mode to digio.TRIG_BYPASS and use the digio.writebit() and digio.writeport() commands.","Example","digio.trigger[4].mode = 2","Sets the trigger mode for I/O line 4 to digio.TRIG_RISING.","Also see","digio.trigger[N].clear()","digio.trigger[N].reset()","digio.writebit()","digio.writeport()","Sweep operation","digio.trigger[N].mode","14674.htm"); +Page[102]=new Array("This attribute returns the event detector overrun status. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Instrument reset
Digital I/O trigger N clear
Digital I/O trigger N reset
Recall setup","Not saved","Not applicable","Usage","overrun = digio.trigger[N].overrun","overrun","Trigger overrun state (true or false)","N","Digital I/O trigger line (1 to 14)","Details","If this is true, an event was ignored because the event detector was already in the detected state when the event occurred.","This is an indication of the state of the event detector built into the line itself. It does not indicate if an overrun occurred in any other part of the trigger model or in any other detector that is monitoring the event.","Example","overrun = digio.trigger[1].overrun","print(overrun)","If there is no trigger overrun, the following text is output:","false","Also see","digio.trigger[N].clear()","digio.trigger[N].reset()","digio.trigger[N].overrun","14675.htm"); +Page[103]=new Array("This attribute describes the length of time that the trigger line is asserted for output triggers. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Digital I/O trigger N reset
Recall setup","Not saved ","10e-6 (10 µs)","Usage","width = digio.trigger[N].pulsewidth","digio.trigger[N].pulsewidth = width","width","The pulse width (seconds)","N","Digital I/O trigger line (1 to 14)","Details","Setting the pulse width to zero (0) seconds asserts the trigger indefinitely. To release the trigger line, use digio.trigger[N].release().","Example","digio.trigger[4].pulsewidth = 20e-6","Sets the pulse width for trigger line 4 to 20 μs.","Also see","digio.trigger[N].assert()","digio.trigger[N].reset()","digio.trigger[N].release()","digio.trigger[N].pulsewidth","17691.htm"); +Page[104]=new Array("This function releases an indefinite length or latched trigger. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","digio.trigger[N].release()","N","Digital I/O trigger line (1 to 14)","Details","Releases a trigger that was asserted with an indefinite pulsewidth time. It also releases a trigger that was latched in response to receiving a synchronous mode trigger. Only the specified trigger line is affected.","Example","digio.trigger[4].release()","Releases digital I/O trigger line 4.","Also see","digio.trigger[N].assert()","digio.trigger[N].pulsewidth","digio.trigger[N].release()","14677.htm"); +Page[105]=new Array("This function resets trigger values to their factory defaults. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","digio.trigger[N].reset()","N","Digital I/O trigger line (1 to 14)","Details","This function resets the following attributes to factory default settings:","digio.trigger[N].mode","digio.trigger[N].pulsewidth","digio.trigger[N].stimulus","It also clears digio.trigger[N].overrun.","Example","digio.trigger[3].mode = 2","digio.trigger[3].pulsewidth = 50e-6","digio.trigger[3].stimulus = digio.trigger[5].EVENT_ID","print(digio.trigger[3].mode, digio.trigger[3].pulsewidth, digio.trigger[3].stimulus)","digio.trigger[3].reset()","print(digio.trigger[3].mode, digio.trigger[3].pulsewidth, digio.trigger[3].stimulus)","Set the digital I/O trigger line 3 for a falling edge with a pulsewidth of 50 µs.","Use digital I/O line 5 to trigger the event on line 3.","Reset the line back to factory default values.","Output before reset:","2.00000e+00 5.00000e-05 5.00000e+00","Output after reset:","0.00000e+00 1.00000e-05 0.00000e+00","Also see","digio.trigger[N].mode","digio.trigger[N].overrun","digio.trigger[N].pulsewidth","digio.trigger[N].stimulus","digio.trigger[N].reset()","17719.htm"); +Page[106]=new Array("This attribute selects the event that causes a trigger to be asserted on the digital output line. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Digital I/O trigger N reset
Recall setup","Not saved","0","Usage","triggerStimulus = digio.trigger[N].stimulus","digio.trigger[N].stimulus = triggerStimulus","triggerStimulus","The event identifier for the triggering event","N","Digital I/O trigger line (1 to 14)","Details","Set this attribute to zero (0) to disable the automatic trigger output.","Do not use the stimulus attribute for generating output triggers under script control. Use digio.trigger[N].assert() instead.","The trigger stimulus for a digital I/O line may be set to one of the existing trigger event IDs, described in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Example 1","digio.trigger[3].stimulus = 0","Clear the trigger stimulus of digital I/O line 3.","Example 2","digio.trigger[3].stimulus = smua.trigger.SOURCE_COMPLETE_EVENT_ID","Set the trigger stimulus of digital I/O line 3 to be the source complete event.","Also see","digio.trigger[N].assert()","digio.trigger[N].clear()","digio.trigger[N].reset()","digio.trigger[N].stimulus","26898.htm"); +Page[107]=new Array("This function waits for a trigger. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","triggered = digio.trigger[N].wait(timeout)","triggered","The value true if a trigger is detected, or false if no triggers are detected during the timeout period","N","Digital I/O trigger line (1 to 14)","timeout","Timeout in seconds","Details","This function pauses for up to timeout seconds for an input trigger. If one or more trigger events are detected since the last time digio.trigger[N].wait() or digio.trigger[N].clear() was called, this function returns a value immediately. After waiting for a trigger with this function, the event detector is automatically reset and ready to detect the next trigger. This is true regardless of the number of events detected.","Example","triggered = digio.trigger[4].wait(3)","print(triggered)","Waits up to three seconds for a trigger to be detected on trigger line 4, then outputs the results.","Output if no trigger is detected:","false","Output if a trigger is detected:","true","Also see","digio.trigger[N].clear()","digio.trigger[N].wait()","14679.htm"); +Page[108]=new Array("This function sets a digital I/O line high or low. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","digio.writebit(N, data)","N","Digital I/O trigger line (1 to 14)","data","The value to write to the bit:","0 (low)","Non‑zero (high)","Details","If the output line is write‑protected using the digio.writeprotect attribute, the command is ignored.","The reset() function does not affect the present state of the digital I/O lines.","Use the digio.writebit() and digio.writeport() commands to control the output state of the synchronization line when trigger operation is set to digio.TRIG_BYPASS.","The data must be zero (0) to clear the bit. Any value other than zero (0) sets the bit.","Example","digio.writebit(4, 0)","Sets digital I/O line 4 low (0).","Also see","digio.readbit()","digio.readport()","digio.trigger[N].mode","digio.writeport()","digio.writeprotect","digio.writebit()","14680.htm"); +Page[109]=new Array("This function writes to all digital I/O lines. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","digio.writeport(data)","data","Value to write to the port (0 to 16383)","Details","The binary representation of data indicates the output pattern to be written to the I/O port. For example, a data value of 170 has a binary equivalent of 00000010101010. Lines 2, 4, 6, and 8 are set high (1), and the other 10 lines are set low (0).","Write‑protected lines are not changed.","The reset() function does not affect the present states of the digital I/O lines.","Use the digio.writebit() and digio.writeport() commands to control the output state of the synchronization line when trigger operation is set to digio.TRIG_BYPASS.","Example","digio.writeport(255)","Sets digital I/O Lines 1 through 8 high (binary 00000011111111).","Also see","digio.readbit()","digio.readport()","digio.writebit()","digio.writeprotect","digio.writeport()","14681.htm"); +Page[110]=new Array("This attribute contains the write‑protect mask that protects bits from changes from the digio.writebit() and digio.writeport() functions. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Saved setup","0"," ","Usage","mask = digio.writeprotect","digio.writeprotect = mask","mask","Sets the value that specifies the bit pattern for write‑protect","Details","Bits that are set to one cause the corresponding line to be write‑protected.","The binary equivalent of mask indicates the mask to be set for the I/O port. For example, a mask value of 7 has a binary equivalent of 00000000000111. This mask write‑protects lines 1, 2, and 3.","Example","digio.writeprotect = 15","Write‑protects lines 1, 2, 3, and 4.","Also see","digio.writebit()","digio.writeport()","digio.writeprotect","14682.htm"); +Page[111]=new Array("This function clears all lines of the front‑panel display.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.clear()","Details","This function switches to the user screen and then clears the front‑panel display.","The display.clear(), display.setcursor(), and display.settext() functions are overlapped commands. That is, the script does not wait for one of these commands to complete. These functions do not immediately update the display. For performance considerations, they update the display as soon as processing time becomes available.","Also see","display.setcursor()","display.settext()","display.clear()","14699.htm"); +Page[112]=new Array("This function reads the annunciators (indicators) that are presently turned on.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","annunciators = display.getannunciators()","annunciators","The bitmasked value that shows which indicators are turned on","Details","This function returns a bitmasked value showing which indicators are turned on. The 16‑bit binary equivalent of the returned value is the bitmask. The return value is a sum of set annunciators, based on the weighted value, as shown in the following table.","Annunciator (indicator) bitmasked values and equivalent constants","Indicator","Bit","Weighted value","Equivalent constant","FILT","1","1","display.ANNUNCIATOR_FILTER","MATH","2","2","display.ANNUNCIATOR_MATH","4W","3","4","display.ANNUNCIATOR_4_WIRE","AUTO","4","8","display.ANNUNCIATOR_AUTO","ARM","5","16","display.ANNUNCIATOR_ARM","TRIG","6","32","display.ANNUNCIATOR_TRIGGER","* (asterisk)","7","64","display.ANNUNCIATOR_STAR","SMPL","8","128","display.ANNUNCIATOR_SAMPLE","EDIT","9","256","display.ANNUNCIATOR_EDIT","ERR","10","512","display.ANNUNCIATOR_ERROR","REM","11","1024","display.ANNUNCIATOR_REMOTE","TALK","12","2048","display.ANNUNCIATOR_TALK ","LSTN","13","4096","display.ANNUNCIATOR_LISTEN","SRQ","14","8192","display.ANNUNCIATOR_SRQ","REAR","15","16384","display.ANNUNCIATOR_REAR","REL","16","32768","display.ANNUNCIATOR_REL","Example 1","testAnnunciators = display.getannunciators()","print(testAnnunciators)","rem = bit.bitand(testAnnunciators, 1024)","if rem > 0 then"," print("REM is on")","else"," print("REM is off")","end","REM indicator is turned on.","Output:","1.28000e+03","REM is on","Example 2","print(display.ANNUNCIATOR_EDIT)","print(display.ANNUNCIATOR_TRIGGER)","print(display.ANNUNCIATOR_AUTO)","Output:","2.56000e+02","3.20000e+01","8.00000e+00","Also see","bit.bitand()","display.getannunciators()","14719.htm"); +Page[113]=new Array("This function reads the present position of the cursor on the front‑panel display.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","row, column, style = display.getcursor()","row","The row where the cursor is: 1 (top row); 2 (bottom row)","column","The column where the cursor is:","If the cursor is in the top row: 1 to 20","If the cursor is in the bottom row: 1 to 32","style","Visibility of the cursor:","Invisible: 0","Blinking: 1","Details","This function switches the front‑panel display to the user screen (the text set by display.settext()), and then returns values to indicate the cursor's row and column position and cursor style.","Columns are numbered from left to right on the display.","Example 1","testRow, testColumn = display.getcursor()","print(testRow, testColumn)","This example reads the cursor position into local variables and prints them. Example output:","1.00000e+00 1.00000e+00","Example 2","print(display.getcursor())","This example prints the cursor position directly. In this example, the cursor is in row 1 at column 3, with an invisible cursor:","1.00000e+00 3.00000e+00 0.00000e+00","Also see","display.gettext()","display.screen","display.setcursor()","display.settext()","display.getcursor()","14700.htm"); +Page[114]=new Array("This function retrieves the key code for the last pressed key.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","keyCode = display.getlastkey()","keyCode","A returned value that represents the last front-panel key pressed; see Details for more information","Details","A history of the key code for the last pressed front‑panel key is maintained by the instrument. When the instrument is turned on, or when it is transitioning from local to remote operation, the key code is set to 0 (display.KEY_NONE).","Pressing the EXIT (LOCAL) key normally aborts a script. To use this function with the EXIT (LOCAL) key, you must set display.locallockout to display.LOCK.","The table below lists the keyCode value for each front‑panel action.","Key codes","Value","Key list","Value","Key list","0","display.KEY_NONE","82","display.KEY_ENTER","65","display.KEY_RANGEUP","85","display.KEY_RECALL","68","display.KEY_MENU","86","display.KEY_MEASA","69","display.KEY_MODEA","87","display.KEY_DIGITSA","70","display.KEY_RELA","92","display.KEY_TRIG","71","display.KEY_RUN","93","display.KEY_LIMITA","72","display.KEY_DISPLAY","94","display.KEY_SPEEDA","73","display.KEY_AUTO","95","display.KEY_LOAD","75","display.KEY_EXIT","97","display.WHEEL_ENTER","77","display.KEY_FILTERA","103","display.KEY_RIGHT","78","display.KEY_STORE","104","display.KEY_LEFT","79","display.KEY_SRCA","107","display.WHEEL_LEFT","80","display.KEY_CONFIG","114","display.WHEEL_RIGHT","81","display.KEY_RANGEDOWN","@When using this function, use built-in constants such as display.KEY_RIGHT (rather than the numeric value of 103). This will allow for better forward compatibility with firmware revisions.","You cannot use this function to track the OUTPUT ON/OFF control.","Example","key = display.getlastkey()","print(key)","On the front panel, press the MENU key and then send the code shown here. This retrieves the key code for the last pressed key.","Output:","6.80000e+01","Also see","display.locallockout","display.sendkey()","display.getlastkey()","92660.htm"); +Page[115]=new Array("This function reads the text displayed on the front panel.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","text = display.gettext()","text = display.gettext(embellished)","text = display.gettext(embellished, row)","text = display.gettext(embellished, row, columnStart)","text = display.gettext(embellished, row, columnStart, columnEnd)","text","The returned value, which contains the text that is presently displayed","embellished","Indicates type of returned text: false (simple text); true (text with embedded character codes)","row","Selects the row from which to read the text: 1 (row 1); 2 (row 2). If row is not included, both rows of text are read","columnStart","Selects the first column from which to read text; for row 1, the valid column numbers are 1 to 20; for row 2, the valid column numbers are 1 to 32; if nothing is selected, 1 is used","columnEnd","Selects the last column from which to read text; for row 1, the valid column numbers are 1 to 20; for row 2, the valid column numbers are 1 to 32; the default is 20 for row 1, and 32 for row 2","Details","Using the command without any parameters returns both lines of the front‑panel display.","The $N character code is included in the returned value to show where the top line ends and the bottom line begins. This is not affected by the value of embellished.","When embellished is set to true, all other character codes are returned along with the message. When embellished is set to false, only the message and the $N character code is returned. For information on the embedded character codes, see display.settext().","The display is not switched to the user screen (the screen set using display.settext()). Text is read from the active screen.","Example 1","display.clear()","display.setcursor(1, 1)","display.settext("ABCDEFGHIJ$DKLMNOPQRST")","display.setcursor(2, 1)","display.settext("abcdefghijklm$Bnopqrstuvwxyz$F123456")","print(display.gettext())","print(display.gettext(true))","print(display.gettext(false, 2))","print(display.gettext(true, 2, 9))","print(display.gettext(false, 2, 9, 10))","This example shows how to retrieve the display text in multiple ways. The output is:","ABCDEFGHIJKLMNOPQRST$Nabcdefghijklmnopqrstuvwxyz123456","$RABCDEFGHIJ$DKLMNOPQRST$N$Rabcdefghijklm$Bnopqrstuvwxyz$F123456","abcdefghijklmnopqrstuvwxyz123456","$Rijklm$Bnopqrstuvwxyz$F123456","ij","Example 2","display.clear()","display.settext("User Screen")","text = display.gettext()","print(text)","This outputs all text in both lines of the display:","User Screen $N","This indicates that the message “User Screen” is on the top line. The bottom line is blank.","Also see","display.clear()","display.getcursor()","display.setcursor()","display.settext()","display.gettext()","14702.htm"); +Page[116]=new Array("This function displays a formatted input field on the front‑panel display that the operator can edit.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.inputvalue("format")","display.inputvalue("format", default)","display.inputvalue("format", default, minimum)","display.inputvalue("format", default, minimum, maximum)","format","A string that defines how the input field is formatted; see Details for more information","default","The default value for the input value","minimum","The minimum input value","maximum","The maximum input value","Details","The format parameter uses zeros (0), the decimal point, polarity sign, and exponents to define how the input field is formatted. The format parameter can include the options shown in the following table.","Option","Description","Examples","E","Include the E to display the value exponentially","0.00000e+0","+","Allows operators to enter positive or negative values; if the "+" sign is not included, the operator cannot enter a negative value","+0.00","0","Defines the digit positions for the value; you can use up to six zeros (0)","+00.0000e+00",".","Include to have a decimal point appear in the value","+0.00","The default parameter is the value shown when the value is first displayed.","The minimum and maximum parameters can be used to limit the values that can be entered. When + is not selected for format, the minimum limit must be more than or equal to zero (0). When limits are used, you cannot enter values above or below these limits.","The input value is limited to ±1e37.","Before calling display.inputvalue(), you should send a message prompt to the operator using display.prompt(). Make sure to position the cursor where the edit field should appear.","After this command is sent, script execution pauses until you enter a value and press the ENTER key.","For positive and negative entry (plus sign (+) used for the value field and/or the exponent field), polarity of a nonzero value or exponent can be toggled by positioning the cursor on the polarity sign and turning the navigation wheel @. Polarity will also toggle when using the navigation wheel @ to decrease or increase the value or exponent past zero. A zero (0) value or exponent (for example, +00) is always positive and cannot be toggled to negative polarity.","After executing this command and pressing the EXIT (LOCAL) key, the function returns nil.","Example","display.clear()","display.settext("Enter value between$N -0.10 and 2.00: ")","value = display.inputvalue("+0.00", 0.5, -0.1, 2.0)","print("Value entered = ", value)","Displays an editable field (+0.50) for operator input. The valid input range is -0.10 to +2.00, with a default of 0.50.","Output:","Value entered = 1.35000e+00","Also see","display.prompt()","display.setcursor()","display.settext()","display.inputvalue()","14703.htm"); +Page[117]=new Array("This function adds an entry to the USER menu, which can be accessed by pressing the LOAD key on the front panel.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.loadmenu.add("displayName", "code")","display.loadmenu.add("displayName", "code", memory)","displayName","The name that is added to the USER menu","code","The code that is run from the USER menu","memory","Determines if code is saved to nonvolatile memory:","0 or display.DONT_SAVE: Does not save the code to nonvolatile memory","1 or display.SAVE: Saves the code to nonvolatile memory (default)","Details","After adding code to the load menu, you can run it from the front panel by pressing the LOAD key, then selecting USER to select from the available code to load. Pressing the RUN key will then run the script.","You can add items in any order. They are always displayed in alphabetic order when the menu is selected.","Any Lua code can be included in the code parameter. If memory is set to display.SAVE, the entry (name and code) is saved in nonvolatile memory. Scripts, functions, and variables used in the code are not saved by display.SAVE. Functions and variables need to be saved with the code. If the code is not saved in nonvolatile memory, it is lost when the 2601B-PULSE is turned off. See Example 2 below.","If you do not make a selection for memory, the code is automatically saved to nonvolatile memory.","@You can create a script that defines several functions, and then use the display.loadmenu.add() command to add items that call those individual functions. This allows the operator to run tests from the front panel.","Example 1","display.loadmenu.add("Test9", "Test9()")","Assume a user script named "Test9" has been loaded into the runtime environment. Adds the menu entry to the USER menu to run the script after loading.","Example 2","display.loadmenu.add("Test", "DUT1() beeper.beep(2, 500)", display.SAVE)","Assume a script with a function named “DUT1” has already been loaded into the instrument, and the script has not been saved in nonvolatile memory.","Now assume you want to add a test named “Test” to the USER menu. You want the test to run the function named “DUT1” and sound the beeper. This example adds “Test” to the menu, defines the code, and then saves the displayName and code in nonvolatile memory.","When “Test” is run from the front panel USER menu, the function named “DUT1” executes and the beeper beeps for two seconds.","Now assume you turn off instrument power. Because the script was not saved in nonvolatile memory, the function named “DUT1” is lost when you turn the instrument on. When “Test” is again run from the front panel, an error is generated because DUT1 no longer exists in the instrument as a function.","Example 3","display.loadmenu.add("Part1", "testpart([[Part1]], 5.0)", display.SAVE)","Adds an entry called “Part1” to the front panel USER load menu for the code testpart([[Part1]], 5.0), and saves it in nonvolatile memory.","Also see","display.loadmenu.delete()","display.loadmenu.add()","19382.htm"); +Page[118]=new Array("This function creates an iterator for the user menu items accessed using the LOAD key on the front panel.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","for displayName in display.loadmenu.catalog() do body end","for displayName, code in display.loadmenu.catalog() do body end","displayName","The name displayed in the menu","code","The code associated with the displayName","body","The body of the code to process the entries in the loop","Details","Each time through the loop, displayName and code will take on the values in the USER menu.","The instrument goes through the list in random order.","Example","for displayName, code in display.loadmenu.catalog() do"," print(displayName, code)","end","Output:","Test DUT1() beeper.beep(2, 500)","Part1 testpart([[Part1]], 5.0)","Test9 Test9()","Also see","display.loadmenu.add()","display.loadmenu.delete()","display.loadmenu.catalog()","14705.htm"); +Page[119]=new Array("This function removes an entry from the USER menu, which can be accessed using the LOAD key on the front panel.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.loadmenu.delete("displayName")","displayName","The name to be deleted from the USER menu","Details","If you delete an entry from the USER menu, you can no longer run it by pressing the LOAD key.","Example","display.loadmenu.delete("Test9")","for displayName, code in display.loadmenu.catalog() do"," print(displayName, code)","end","Deletes the entry named Test9.","Output:","Test DUT1() beeper.beep(2, 500)","Part1 testpart([[Part1]], 5.0)","Also see","display.loadmenu.add()","display.loadmenu.catalog()","display.loadmenu.delete()","14706.htm"); +Page[120]=new Array("This attribute describes whether or not the EXIT (LOCAL) key on the instrument front panel is enabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Power cycle","Not saved","0 (display.UNLOCK)","Usage","lockout = display.locallockout","display.locallockout = lockout","lockout","0 or display.UNLOCK: Unlocks EXIT (LOCAL) key","1 or display.LOCK: Locks out EXIT (LOCAL) key","Details","Set display.locallockout to display.LOCK to prevent the user from interrupting remote operation by pressing the EXIT (LOCAL) key.","Set this attribute to display.UNLOCK to allow the EXIT (LOCAL) key to interrupt script or remote operation.","Example","display.locallockout = display.LOCK","Disables the front‑panel EXIT (LOCAL) key.","Also see","None","display.locallockout","14707.htm"); +Page[121]=new Array("This function presents a menu on the front‑panel display.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","selection = display.menu("name", "items")","selection","Name of the variable that holds the selected menu item","name","Menu name to display on the top line","items","Menu items to display on the bottom line","Details","The menu consists of the menu name string on the top line, and a selectable list of items on the bottom line. The menu items must be a single string with each item separated by whitespace. The name for the top line is limited to 20 characters.","After sending this command, script execution pauses for the operator to select a menu item. An item is selected by rotating the navigation wheel @ to place the blinking cursor on the item, and then pressing the navigation wheel @ (or the ENTER key). When an item is selected, the text of that selection is returned.","Pressing the EXIT (LOCAL) key will not abort the script while the menu is displayed, but it will return nil. The script can be aborted by calling the exit function when nil is returned.","Example","selection = display.menu("Menu", "Test1 Test2 Test3")","print(selection)","Displays a menu with three menu items. If the second menu item is selected, selection is given the value Test2.","Output:","Test2","Also see","None","display.menu()","14708.htm"); +Page[122]=new Array("This attribute controls whether the front panel keys act as a numeric keypad during value entry.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Saved setup","1 (display.ENABLE)","Usage","numericKeypad = display.numpad","display.numpad = numericKeypad","numericKeypad","Enable the numeric keypad feature (1 or display.ENABLE)","Disable the numeric keypad feature (0 or display.DISABLE)","Details","The numeric keypad feature is only available when editing a numeric value at the same time that the EDIT indicator is lit.","Example","display.numpad = display.ENABLE","Turn on the numeric keypad feature.","Also see","Setting a value","display.numpad","14709.htm"); +Page[123]=new Array("This function prompts the user to enter a parameter from the front panel of the instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.prompt("format", "units", "help")","display.prompt("format", "units", "help", default)","display.prompt("format", "units", "help", default, minimum)","display.prompt("format", "units", "help", default, minimum, maximum)","format","A string that defines how the input field is formatted; see Details for more information","units","Set the units text string for the top line (eight characters maximum); this indicates the units (for example, "V" or "A") for the value","help","Text string to display on the bottom line (32 characters maximum)","default","The value that is shown when the value is first displayed","minimum","The minimum input value that can be entered","maximum","The maximum input value that can be entered (must be more than minimum)","Details","This function creates an editable input field at the present cursor position, and an input prompt message on the bottom line. Example of a displayed input field and prompt:","0.00V","Input 0 to +2V","The format parameter uses zeros (0), the decimal point, polarity sign, and exponents to define how the input field is formatted.","The format parameter can include the options shown in the following table.","Option","Description","Examples","E","Include the E to display the value exponentially. Include a plus sign (+) for positive/negative exponent entry. Do not include the plus sign (+) to prevent negative value entry. 0 defines the digit positions for the exponent.","0.00000E+0","+","Allows operators to enter positive or negative values. If the plus sign (+) is not included, the operator cannot enter a negative value.","+0.00","0","Defines the digit positions for the value. You can use up to six zeros (0).","+00.0000E+00",".","The decimal point where needed for the value.","+0.00","You can use the minimum and maximum parameters to limit the values that can be entered. When a plus sign (+) is not selected for format, the minimum limit must be greater than or equal to zero (0). When limits are used, the operator cannot enter values above or below these limits.","The input value is limited to ±1e37.","After sending this command, script execution pauses for the operator to enter a value and press ENTER.","For positive and negative entry (plus sign (+) used for the value field and the exponent field), polarity of a nonzero value or exponent can be toggled by positioning the cursor on the polarity sign and turning the navigation wheel @. Polarity will also toggle when using the navigation wheel @ to decrease or increase the value or exponent past zero. A zero value or exponent (for example, +00) is always positive and cannot be toggled to negative polarity.","After executing this command and pressing the EXIT (LOCAL) key, the value returns nil.","Example","value = display.prompt("0.00", "V", "Input 0 to +2V", 0.5, 0, 2)","print(value)","The above command prompts the operator to enter a voltage value. The valid input range is 0 to +2.00, with a default of 0.50:","0.50V","Input 0 to +2V","If the operator enters 0.70, the output is:","7.00000e-01","Also see","display.inputvalue()","display.prompt()","14740.htm"); +Page[124]=new Array("This attribute contains the selected display screen.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Saved setup","0 (display.SMUA)","Usage","displayID = display.screen","display.screen = displayID","displayID","One of the following values:","0 or display.SMUA: Displays source-measure and compliance values","3 or display.USER: Displays the user screen","Details","Setting this attribute selects the display screen for the front panel. This performs the same action as pressing the DISPLAY key on the front panel. The text for the display screen is set by display.settext().","Read this attribute to determine which of the available display screens was last selected.","Example","display.screen = display.SMUA","Selects the source-measure and compliance limit display.","Also see","display.settext()","display.screen","92282.htm"); +Page[125]=new Array("This function sends a code that simulates the action of a front‑panel control.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.sendkey(keyCode)","keyCode","A parameter that specifies the key press to simulate; see Details for more information","Details","This command simulates pressing a front‑panel key or navigation wheel, or turning the navigation wheel one click to the left or right.","Key codes","Value","Key list","Value","Key list","65","display.KEY_RANGEUP","85","display.KEY_RECALL","68","display.KEY_MENU","86","display.KEY_MEASA","69","display.KEY_MODEA","87","display.KEY_DIGITSA","70","display.KEY_RELA","88","display.KEY_OUTPUTA","71","display.KEY_RUN","92","display.KEY_TRIG","72","display.KEY_DISPLAY","93","display.KEY_LIMITA","73","display.KEY_AUTO","94","display.KEY_SPEEDA","75","display.KEY_EXIT","95","display.KEY_LOAD","77","display.KEY_FILTERA","97","display.WHEEL_ENTER","78","display.KEY_STORE","103","display.KEY_RIGHT","79","display.KEY_SRCA","104","display.KEY_LEFT","80","display.KEY_CONFIG","107","display.WHEEL_LEFT","81","display.KEY_RANGEDOWN","114","display.WHEEL_RIGHT","82","display.KEY_ENTER","@When using this function, send built-in constants, such as display.KEY_RIGHT, rather than the numeric value, such as 103. This allows for better forward compatibility with firmware revisions.","Example","display.sendkey(display.KEY_RUN)","Simulates pressing the RUN key.","Also see","Front panel","display.sendkey()","92659.htm"); +Page[126]=new Array("This attribute sets the front‑panel display resolution of the selected measurement.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Saved setup","5 (display.DIGITS_5_5)","Usage","digits = display.smua.digits","display.smua.digits = digits","digits","Set digits to one of the following values:","Select 4-1/2 digit resolution (4 or display.DIGITS_4_5)","Select 5-1/2 digit resolution (5 or display.DIGITS_5_5)","Select 6-1/2 digit resolution (6 or display.DIGITS_6_5)","Details","This attribute sets the display resolution.","Example","display.smua.digits = display.DIGITS_5_5","Select 5-1/2 digit resolution.","Also see","Display resolution","display.smua.digits","92073.htm"); +Page[127]=new Array("This function sets the position of the cursor.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.setcursor(row, column)","display.setcursor(row, column, style)","row","The row number for the cursor (1 or 2)","column","The active column position to set; row 1 has columns 1 to 20, row 2 has columns 1 to 32","style","Set the cursor to invisible (0, default) or blinking (1)","Details","Sending this command selects the user screen and then moves the cursor to the given location.","The display.clear(), display.setcursor(), and display.settext() functions are overlapped commands. That is, the script does not wait for one of these commands to complete. These functions do not immediately update the display. For performance considerations, they update the display as soon as processing time becomes available.","An out‑of-range parameter for row sets the cursor to row 2. An out‑of‑range parameter for column sets the cursor to column 20 for row 1, or 32 for row 2.","An out‑of‑range parameter for style sets it to 0 (invisible).","A blinking cursor is only visible when it is positioned over displayed text. It cannot be seen when positioned over a space character.","Example","display.clear()","display.setcursor(1, 8)","display.settext("Hello")","display.setcursor(2, 14)","display.settext("World")","This example displays a message on the front panel, approximately center. Note that the top line of text is larger than the bottom line of text.","The front panel of the instrument displays "Hello" on the top line and "World" on the second line.","Also see","display.clear()","display.getcursor()","display.gettext()","display.screen","display.settext()","display.setcursor()","14711.htm"); +Page[128]=new Array("This function displays text on the front‑panel user screen.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.settext("text")","text","Text message to be displayed, with optional character codes","Details","This function selects the user display screen and displays the given text.","After the instrument is turned on, the first time you use a display command to write to the display, the message "User Screen" is cleared. After the first write, you need to use display.clear() to clear the message.","The display.clear(), display.setcursor(), and display.settext() functions are overlapped commands. That is, the script does not wait for one of these commands to complete. These functions do not immediately update the display. For performance considerations, they update the display as soon as processing time becomes available.","The text starts at the present cursor position. After the text is displayed, the cursor is after the last character in the display message.","Top line text does not wrap to the bottom line of the display automatically. Any text that does not fit on the current line is truncated. If the text is truncated, the cursor remains at the end of the line.","The text remains on the display until replaced or cleared.","The character codes described in the following table can be also be included in the text string.","Display character codes","Character Code","Description","$N","Newline, starts text on the next line; if the cursor is already on line 2, text will be ignored after the $N is received","$R","Sets text to normal intensity, nonblinking","$B","Sets text to blink","$D","Sets text to dim intensity","$F","Sets the text to background blink","$$","Escape sequence to display a single dollar symbol ($)","Example","display.clear()","display.settext("Normal $BBlinking$N")","display.settext("$DDim $FBackgroundBlink$R $$$$ 2 dollars")","This example sets the display to:","Normal Blinking","Dim BackgroundBlink $$ 2 dollars","with the named effect on each word.","Also see","display.clear()","display.getcursor()","display.gettext()","display.screen","display.setcursor()","display.settext()","14712.htm"); +Page[129]=new Array("This attribute specifies the type of limit value setting displayed for the SMU.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Saved setup","0 (display.LIMIT_IV)","Usage","func = display.smua.limit.func","display.smua.limit.func = func","func","One of the following values:","0 or display.LIMIT_IV: Displays the primary limit setting","1 or display.LIMIT_P: Displays the power limit setting","Details","Selects the displayed limit function for the SMU: primary (IV) or power (P).","Example","display.smua.limit.func = display.LIMIT_P","Specifies that the power limit value is displayed.","Also see","display.smua.measure.func","Display mode","display.smua.limit.func","92074.htm"); +Page[130]=new Array("This attribute specifies the type of measurement that is being displayed.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Saved setup","1 (display.MEASURE_DCVOLTS)","Usage","func = display.smua.measure.func","display.smua.measure.func = func","func","The type of measurement:","0 or display.MEASURE_DCAMPS: Current measurement function","1 or display.MEASURE_DCVOLTS: Voltage measurement function","2 or display.MEASURE_OHMS: Resistance measurement function","3 or display.MEASURE_WATTS: Power measurement function","Details","Selects the measurement function that is displayed on the front panel: Amps, volts, ohms, or watts.","Example","display.smua.measure.func = display.MEASURE_DCAMPS","Selects the current measure function.","Also see","display.smua.limit.func","display.smua.measure.func","92075.htm"); +Page[131]=new Array("This function clears the front‑panel trigger event detector.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","display.trigger.clear()","Details","The trigger event detector remembers if an event has been detected since the last display.trigger.wait() call. This function clears the trigger event detector and discards the previous history of TRIG key presses.","This attribute also clears the display.trigger.overrun attribute.","Also see","display.trigger.overrun","display.trigger.wait()","display.trigger.clear()","14715.htm"); +Page[132]=new Array("This constant is the event ID of the event generated when the front‑panel TRIG key is pressed.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = display.trigger.EVENT_ID","eventID","The trigger event number","Details","Set the stimulus of any trigger event detector to the value of this constant to have it respond to front-panel trigger key events.","Also see","None","display.trigger.EVENT_ID","14716.htm"); +Page[133]=new Array("This attribute contains the event detector overrun status.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Display trigger clear
Instrument reset
Recall setup","Not saved","false","Usage","overrun = display.trigger.overrun","overrun","The trigger overrun state (true or false)","Details","Indicates if a trigger event was ignored because the event detector was already in the detected state when the TRIG button was pressed.","Indicates the overrun state of the event detector built into the display.","This attribute does not indicate whether an overrun occurred in any other part of the trigger model or in any other detector that is monitoring the event.","Example","overrun = display.trigger.overrun","Sets the variable overrun equal to the present state of the event detector built into the display. ","Also see","display.trigger.clear()","display.trigger.overrun","14739.htm"); +Page[134]=new Array("This function waits for the TRIG key on the front panel to be pressed.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","triggered = display.trigger.wait(timeout)","triggered","true: Trigger was detected","false: The operation timed out","timeout","Timeout in seconds","Details","If the trigger key was previously pressed and one or more trigger events were detected, this function returns immediately.","After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.","Use the display.trigger.clear() call to clear the trigger event detector.","Example","triggered = display.trigger.wait(5)","print(triggered)","Waits up to five seconds for the TRIG key to be pressed. If TRIG is pressed within five seconds, the output is true. If not, the output is false.","Also see","display.trigger.clear()","display.trigger.wait()","14717.htm"); +Page[135]=new Array("This function captures the key code value for the next front‑panel action.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","keyCode = display.waitkey()","keyCode","See Details for more information","Details","After you send this function, script execution pauses until a front‑panel action (for example, pressing a key or the navigation wheel @, or turning the navigation wheel @). After the action, the value of the key (or action) is returned.","If the EXIT (LOCAL) key is pressed while this function is waiting for a front‑panel action, the script is not aborted.","A typical use for this function is to prompt the user to press the EXIT (LOCAL) key to abort the script or press any other key to continue. For example, if the keyCode value 75 is returned (the EXIT (LOCAL) key was pressed), you can call the exit() function to abort the script.","The table below lists the keyCode values for each front panel action.","Key codes","Value","Key list","Value","Key list","65","display.KEY_RANGEUP","85","display.KEY_RECALL","68","display.KEY_MENU","86","display.KEY_MEASA","69","display.KEY_MODEA","87","display.KEY_DIGITSA","70","display.KEY_RELA","88","display.KEY_OUTPUTA","71","display.KEY_RUN","92","display.KEY_TRIG","72","display.KEY_DISPLAY","93","display.KEY_LIMITA","73","display.KEY_AUTO","94","display.KEY_SPEEDA","75","display.KEY_EXIT","95","display.KEY_LOAD","77","display.KEY_FILTERA","97","display.WHEEL_ENTER","78","display.KEY_STORE","103","display.KEY_RIGHT","79","display.KEY_SRCA","104","display.KEY_LEFT","80","display.KEY_CONFIG","107","display.WHEEL_LEFT","81","display.KEY_RANGEDOWN","114","display.WHEEL_RIGHT","82","display.KEY_ENTER","@When using this function, send built-in constants, such as display.KEY_RIGHT, rather than the numeric value, such as 103. This allows for better forward compatibility with firmware revisions.","Example","key = display.waitkey()","print(key)","Pause script execution until the operator presses a key or the navigation wheel @, or rotates the navigation wheel.","If the output is:","8.60000e+01","It indicates that the MEAS(A) key was pressed.","Also see","Capturing key-press codes","display.getlastkey()","display.sendkey()","display.settext()","display.waitkey()","92661.htm"); +Page[136]=new Array("This function clears all entries out of the error queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","errorqueue.clear()","Details","See the Error queue topic for additional information about the error queue.","Also see","errorqueue.count","errorqueue.next()","errorqueue.clear()","14749.htm"); +Page[137]=new Array("This attribute gets the number of entries in the error queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Power cycle
Clearing error queue
Reading error messages","Not applicable","Not applicable","Usage","count = errorqueue.count","count","The number of entries in the error queue","Example","count = errorqueue.count","print(count)","Returns the number of entries in the error queue.","The output below indicates that there are four entries in the error queue:","4.00000e+00","Also see","Error queue","errorqueue.clear()","errorqueue.next()","errorqueue.count","14750.htm"); +Page[138]=new Array("This function reads the oldest entry from the error queue and removes it from the queue.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","errorCode, message, severity, errorNode = errorqueue.next()","errorCode","The error code number for the entry","message","The message that describes the error code","severity","The severity level (0, 10, 20, 30, or 40); see Details for more information","errorNode","The node number where the error originated","Details","Entries are stored in a first-in, first-out (FIFO) queue. This function reads the oldest entry and removes it from the queue.","Error codes and messages are listed in the Error summary list.","If there are no entries in the queue, code 0, "Queue is Empty" is returned.","Returned severity levels are described in the following table.","Number","Error level","Description","0","NO_SEVERITY","The message is information only. This level is used when the Error Queue is empty; the message does not represent an error.","10","INFORMATIONAL","The message is information only. This level is used to indicate status changes; the message does not represent an error.","20","RECOVERABLE","The error was caused by improper use of the instrument or by conditions that can be corrected. This message indicates that an error occurred. The instrument is still operating normally.","30","SERIOUS","There is a condition that prevents the instrument from functioning properly. The message indicates that the instrument is presently operating in an error condition. If the condition is corrected, the instrument will return to normal operation.","40","FATAL","There is a condition that cannot be corrected that prevents the instrument from functioning properly. Disconnect the DUT and turn the power off and then on again. If the error is a hardware fault that persists after cycling the power, the instrument must be repaired.","In an expanded system, each TSP‑Link enabled instrument is assigned a node number. The variable errorNode stores the node number where the error originated.","Example","errorcode, message = errorqueue.next()","print(errorcode, message)","Reads the oldest entry in the error queue. The output below indicates that the queue is empty.","Output:","0.00000e+00 Queue Is Empty","Also see","Error queue","errorqueue.clear()","errorqueue.count","Error summary list","errorqueue.next()","92325.htm"); +Page[139]=new Array("This function returns all entries from the event log as a single string and removes them from the event log.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","logString = eventlog.all()","logString","A listing of all event log entries","Details","This function returns all events in the event log. Logged items are shown from oldest to newest. The response is a string that has the messages delimited with a new line character.","This function also clears the event log.","If there are no entries in the event log, this function returns the value nil.","Example","print(eventlog.all())","Get and print all entries from the event log and remove the entries from the log.","Output:","17:26:35.690 10 Oct 2019, LAN0, 192.168.1.102, LXI, 0, 1570728395,
1192037155.733269000, 0, 0x0","17:26:39.009 10 Oct 2019, LAN5, 192.168.1.102, LXI, 0, 1570728399,
1192037159.052777000, 0, 0x0","Also see","eventlog.clear()","eventlog.count","eventlog.enable","eventlog.next()","eventlog.overwritemethod","eventlog.all()","14756.htm"); +Page[140]=new Array("This function clears the event log.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","eventlog.clear()","Details","This command removes all messages from the event log.","Also see","eventlog.all()","eventlog.count","eventlog.enable","eventlog.next()","eventlog.overwritemethod","eventlog.clear()","14758.htm"); +Page[141]=new Array("This attribute returns the number of unread events in the event log.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Instrument reset
Clearing event log
Reading event log","Not applicable","Not applicable","Usage","N = eventlog.count","N","The number of events in the event log","Example","print(eventlog.count)","Displays the present number of events in the instrument event log.","Output looks similar to:","3.00000e+00","Also see","eventlog.all()","eventlog.clear()","eventlog.enable","eventlog.next()","eventlog.overwritemethod","eventlog.count","14757.htm"); +Page[142]=new Array("This attribute enables or disables the event log.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Not saved","1 (eventlog.ENABLE)","Usage","status = eventlog.enable","eventlog.enable = status","status","The enable status of the event log:","1 or eventlog.ENABLE: Event log enable","0 or eventlog.DISABLE: Event log disable","Details","When the event log is disabled (eventlog.DISABLE or 0), no new events are added to the event log. You can, however, read and remove existing events.","When the event log is enabled, new events are logged.","Example","print(eventlog.enable)","eventlog.enable = eventlog.DISABLE","print(eventlog.enable)","Displays the present status of the 2601B-PULSE event log.","Output:","1.00000e+00","0.00000e+00","Also see","eventlog.all()","eventlog.clear()","eventlog.count","eventlog.next()","eventlog.overwritemethod","eventlog.enable","14760.htm"); +Page[143]=new Array("This function returns the oldest unread event message from the event log and removes it from the event log.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","logString = eventlog.next()","logString","The next log entry","Details","Returns the next entry from the event log and removes it from the log.","If there are no entries in the event log, returns the value nil.","Example 1","print(eventlog.next())","Get the oldest message in the event log and remove that entry from the log.","Output:","17:28:22.085 10 Oct 2019, LAN2, 192.168.1.102, LXI, 0, 1570728502, <no time>, 0, 0x0","Example 2","print(eventlog.next())","If you send this command when there is nothing in the event log, you will get the following output:","nil","Also see","eventlog.all()","eventlog.clear()","eventlog.count","eventlog.enable","eventlog.overwritemethod","eventlog.next()","14761.htm"); +Page[144]=new Array("This attribute controls how the event log processes events if the event log is full.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Not saved ","1 (eventlog.DISCARD_OLDEST)","Usage","method = eventlog.overwritemethod","eventlog.overwritemethod = method","method","Set to one of the following values:","0 or eventlog.DISCARD_NEWEST: New entries are not logged","1 or eventlog.DISCARD_OLDEST: Old entries are deleted as new events are logged","Details","When this attribute is set to eventlog.DISCARD_NEWEST, new entries are not logged.","When this attribute is set to eventlog.DISCARD_OLDEST, the oldest entry is discarded when a new entry is added.","Example","eventlog.overwritemethod = 0","When the log is full, the event log will ignore new entries.","Also see","eventlog.all()","eventlog.clear()","eventlog.count","eventlog.enable","eventlog.next()","eventlog.overwritemethod","14759.htm"); +Page[145]=new Array("This function stops a script that is presently running.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","exit()","Details","Terminates script execution when called from a script that is being executed.","This command does not wait for overlapped commands to complete before terminating script execution. If overlapped commands are required to finish, use the waitcomplete() function before calling exit().","Also see","waitcomplete()","exit()","14769.htm"); +Page[146]=new Array("This function closes the file that is represented by the fileVar variable.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","fileVar:close()","fileVar","The file descriptor variable to close","Details","This command is equivalent to io.close(fileVar).","Note that files are automatically closed when the file descriptors are garbage collected.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","print("\\n*** fileVar:close")","do","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1")","myfile:close()","end","myfile, myfile_err, myfile_errnum = io.open(fileName, "r")","myfile:close()","os.remove(fileName)","Opens file myfile.txt for writing. If no errors were found while opening, writes Removing file and closes the file.","Also see","fileVar:flush()","fileVar:read()","fileVar:seek()","fileVar:write()","io.close()","io.open()","fileVar:close()","14772.htm"); +Page[147]=new Array("This function writes buffered data to a file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","fileVar:flush()","fileVar","The file descriptor variable to flush","Details","The fileVar:write() or io.write() functions buffer data, which may not be written immediately to the USB flash drive. Use fileVar:flush() to flush this data. Using this function removes the need to close a file after writing to it, allowing the file to be left open to write more data. Data may be lost if the file is not closed or flushed before a script ends. ","If there is going to be a time delay before more data is written to a file, and you want to keep the file open, flush the file after you write to it to prevent loss of data.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","errorqueue.clear()","print("\\n*** io.read")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1\\n")","myfile:flush()","myfile:close()","do","fileHandle = io.input(fileName)","value = io.read("*a")","print(value)","end","fileHandle:close()","print(errorqueue.next())","Writes data to a USB flash drive.","Also see","fileVar:write()","io.open()","io.write()","fileVar:flush()","14786.htm"); +Page[148]=new Array("This function reads data from a file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","data1 = fileVar:read() ","data1 = fileVar:read(format1)","data1, data2 = fileVar:read("format1", "format2")","data1, ..., datan = fileVar:read("format1", ..., "formatn")","data1","First data read from the file","data2","Second data read from the file","datan","Last data read from the file","fileVar","The descriptor of the file to be read","format1","A string or number indicating the first type of data to be read","format2","A string or number indicating the second type of data to be read","formatn","A string or number indicating the last type of data to be read","...","One or more entries (or values) separated by commas","Details","The format parameters may be any of the following:",""*n": Returns a number.",""*a": Returns the whole file, starting at the current position (returns an empty string if the current file position is at the end of the file).",""*l": Returns the next line, skipping the end of line; returns nil if the current file position is at the end of file.","n: Returns a string with up to n characters; returns an empty string if n is zero; returns nil if the current file position is at the end of file.","If no format parameters are provided, the function will perform as if the function is passed the value "*l".","Any number of format parameters may be passed to this command, each corresponding to a returned data value.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","print("fileVar:read")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1")","myfile:close()","do","myfile, myfile_err, myfile_errnum = io.open(fileName, "r")","contents = myfile:read("*a")","print(contents)","end","myfile:close()","os.remove(fileName)","Reads data from the input file.","Also see","fileVar:write()","io.input()","io.open()","fileVar:read()","14787.htm"); +Page[149]=new Array("This function sets and gets the present position of a file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","position, errorMsg = fileVar:seek()","position, errorMsg = fileVar:seek("whence")","position, errorMsg = fileVar:seek("whence", offset)","position","The new file position, measured in bytes from the beginning of the file","errorMsg","A string containing the error message","fileVar","The file descriptor variable","whence","A string indicating the base against which offset is applied; the default is "cur"","offset","The intended new position, measured in bytes from a base indicated by whence (default is 0)","Details","The whence parameters may be any of the following:",""set": Beginning of file",""cur": Current position",""end": End of file","If an error is encountered, it is logged to the error queue, and the command returns nil and the error string.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","errorqueue.clear()","print("\\n*** fileVar:seek")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1")","myfile:close()","do","myfile, myfile_err, myfile_errnum = io.open(fileName, "r")","position = myfile:seek("end", -1)","print(position)","end","myfile:close()","os.remove(fileName)","Get the present position of a file.","Also see","io.open()","fileVar:seek()","14788.htm"); +Page[150]=new Array("This function writes data to a file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","fileVar:write(data)","fileVar:write(data1, data2)","fileVar:write(data1, ..., datan)","fileVar","The file descriptor variable","data","Write all data to the file","data1","The first data to write to the file","data2","The second data to write to the file","datan","The last data to write to the file","...","One or more entries (or values) separated by commas","Details","This function may buffer data until a flush (fileVar:flush() or io.flush()) or close (fileVar:close() or io.close()) operation is performed.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","errorqueue.clear()","print("\\n*** fileVar:write")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","do","myfile:write("Line 1")","end","myfile:close()","os.remove(fileName)","Write data to a file.","Also see","fileVar:close()","fileVar:flush()","io.close()","io.flush()","io.open()","fileVar:write()","14789.htm"); +Page[151]=new Array("This attribute sets the precision (number of digits) for all numbers returned in the ASCII format.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","No","Instrument reset
Recall setup","Not saved","6","Usage","precision = format.asciiprecision","format.asciiprecision = precision","precision","A number representing the number of digits to be printed for numbers printed with the print(), printbuffer(), and printnumber() functions; must be a number between 1 and 16","Details","This attribute specifies the precision (number of digits) for numeric data printed with the print(), printbuffer(), and printnumber() functions. The format.asciiprecision attribute is only used with the ASCII format. The precision value must be a number from 0 to 16.","Note that the precision is the number of significant digits printed. There is always one digit to the left of the decimal point; be sure to include this digit when setting the precision.","Example","format.asciiprecision = 10","x = 2.54","printnumber(x)","format.asciiprecision = 3","printnumber(x)","Output:","2.540000000e+00","2.54e+00","Also see","format.byteorder","format.data","print()","printbuffer()","printnumber()","format.asciiprecision","14797.htm"); +Page[152]=new Array("This attribute sets the binary byte order for the data that is printed using the printnumber() and printbuffer() functions.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Not saved","1 (format.LITTLEENDIAN)","Usage","order = format.byteorder","format.byteorder = order","order","Byte order value as follows:","Most significant byte first: 0, format.NORMAL, format.NETWORK, or format.BIGENDIAN","Least significant byte first: 1, format.SWAPPED or format.LITTLEENDIAN","Details","This attribute selects the byte order in which data is written when you are printing data values with the printnumber() and printbuffer() functions. The byte order attribute is only used with the format.SREAL, format.REAL, format.REAL32, and format.REAL64 data formats.","format.NORMAL, format.BIGENDIAN, and format.NETWORK select the same byte order. format.SWAPPED and format.LITTLEENDIAN select the same byte order. Selecting which to use is a matter of preference.","Select the format.SWAPPED or format.LITTLEENDIAN byte order when sending data to a computer with a Microsoft Windows operating system.","Example","x = 1.23","format.data = format.REAL32","format.byteorder = format.LITTLEENDIAN","printnumber(x)","format.byteorder = format.BIGENDIAN","printnumber(x)","Output depends on the terminal program you use, but will look something like:","#0¤p??","#0??p¤","Also see","format.asciiprecision","format.data","printbuffer()","printnumber()","format.byteorder","14801.htm"); +Page[153]=new Array("This attribute sets the data format for data that is printed using the printnumber() and printbuffer() functions.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","No","Instrument reset
Recall setup","Not saved","1 (format.ASCII)","Usage","value = format.data","format.data = value","value","The format to use for data, set to one of the following values:","ASCII format: 1 or format.ASCII","Single‑precision IEEE Std 754 binary format: 2, format.SREAL, or format.REAL32","Double‑precision IEEE Std 754 binary format: 3, format.REAL, format.REAL64, or format.DREAL","Details","The precision of numeric values can be controlled with the format.asciiprecision attribute. The byte order of format.SREAL, format.REAL, format.REAL32, and format.REAL64 can be selected with the format.byteorder attribute.","REAL32 and SREAL select the same single precision format. REAL and REAL64 select the same double precision format. They are alternative identifiers. Selecting which to use is a matter of preference.","The IEEE Std 754 binary formats use four bytes for single‑precision values and eight bytes for double‑precision values.","When data is written with any of the binary formats, the response message starts with #0 and ends with a new line. When data is written with the ASCII format, elements are separated with a comma and space.","@Binary formats are not intended to be interpreted by humans.","Example","format.asciiprecision = 10","x = 3.14159265","format.data = format.ASCII","printnumber(x)","format.data = format.REAL64","printnumber(x)","Output a number represented by x in ASCII using a precision of 10, then output the same number in binary using double precision format.","Output:","3.141592650e+00","#0ñÔÈSû! @","Also see","format.asciiprecision","format.byteorder","printbuffer()","printnumber()","format.data","14803.htm"); +Page[154]=new Array("This function sets the current working directory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","workingDirectory = fs.chdir("path")","workingDirectory","Returned value containing the working path","path","A string indicating the new working directory path","Details","The new working directory path may be absolute or relative to the current working directory.","An error is logged to the error queue if the given path does not exist.","Example","if fs.is_dir("/usb1/temp") == true then","  fs.chdir("/usb1/temp")","  testPath = fs.cwd()","  print(testPath)","else","  testPath = fs.cwd()","  print(testPath)","end","Insert a USB flash drive into the front panel of the instrument.","Verify that /usb1/temp is a directory and change it to be the current working directory.","Set the variable for the current working directory to be testPath.","The return should be:","/usb1/temp","If /usb1/temp is not a directory, set the variable for the current working directory to be testPath.","The return should be:","/usb1","Also see","None","fs.chdir()","14808.htm"); +Page[155]=new Array("This function returns the absolute path of the current working directory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","path = fs.cwd()","path","The absolute path of the current working directory","Example","if fs.is_dir("/usb1/temp") == true then","  fs.chdir("/usb1/temp")","  testPath = fs.cwd()","  print(testPath)","else","  testPath = fs.cwd()","  print(testPath)","end","Insert a USB flash drive into the front panel of the instrument.","Verify that /usb1/temp is a directory and change it to be the current working directory.","Set the variable for the current working directory to be testPath.","The return should be:","/usb1/temp","If /usb1/temp is not a directory, set the variable for the current working directory to be testPath.","The return should be:","/usb1","Also see","None","fs.cwd()","14810.htm"); +Page[156]=new Array("This function tests whether or not the specified path refers to a directory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","status = fs.is_dir("path")","status","Whether or not the given path is a directory (true or false)","path","The path of the file system entry to test","Details","The file system path may be absolute or relative to the current working system path.","Example 1","print("Is directory: ", fs.is_dir("/usb1/"))","Because /usb1/ is always the root directory of an inserted flash drive, you can use this command to verify that USB flash drive is inserted.","Example 2","if fs.is_dir("/usb1/temp") == false then","    fs.mkdir("/usb1/temp")","end","Insert a USB flash drive into the front panel of the instrument.","Check to see if the temp directory exists.","If it does not exist, create a directory named temp.","Also see","fs.is_file()","fs.is_dir()","14811.htm"); +Page[157]=new Array("Tests whether the specified path refers to a file (as opposed to a directory).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","status = fs.is_file("path")","status","true if the given path is a file; otherwise, false","path","The path of the file system entry to test","Details","The file system path may be absolute or relative to the current working system path.","Example","rootDirectory = "/usb1/"","print("Is file: ", fs.is_file(rootDirectory))","Insert a USB flash drive into the front panel of the instrument.","Set rootDirectory to be the USB port.","Check to see if rootDirectory is a file. Because rootDirectory was set up as a directory, the return is false.","Also see","fs.is_dir()","fs.is_file()","14824.htm"); +Page[158]=new Array("This function creates a directory at the specified path.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","path = fs.mkdir("newPath")","path","The returned path of the new directory","newpath","Location (path) of where to create the new directory","Details","The directory path may be absolute or relative to the current working directory.","An error is logged to the error queue if the parent folder of the new directory does not exist, or if a file system entry already exists at the given path.","Example","if fs.is_dir("/usb1/temp") == false then","    fs.mkdir("/usb1/temp")","end","Insert a USB flash drive into the front panel of the instrument.","Check to see if the temp directory exists.","If it does not exist, create a directory named temp.","Also see","fs.rmdir()","fs.mkdir()","14812.htm"); +Page[159]=new Array("This function returns a list of the file system entries in the directory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","files = fs.readdir("path")","files","A table containing the names of all the file system entries in the specified directory","path","The directory path","Details","The directory path may be absolute or relative to the current working directory.","This command is nonrecursive. For example, entries in subfolders are not returned.","An error is logged to the error queue if the given path does not exist or does not represent a directory.","Example","rootDirectory = "/usb1/"","entries = fs.readdir(rootDirectory)","count = table.getn(entries)","print("Found a total of "..count.." files and directories")","for i = 1, count do"," print(entries[i])","end","Insert a USB flash drive into the front panel of the instrument.","Set rootDirectory to be the USB port.","Set entries as the variable for the file system entries in rootDirectory.","Return the number of files and directories in the directory.","Also see","None","fs.readdir()","14814.htm"); +Page[160]=new Array("This function removes a directory from the file system.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","fs.rmdir("path")","path","The path of the directory to remove","Details","This path may be absolute or relative to the present working directory.","An error is logged to the error queue if the given path does not exist or does not represent a directory. An error is also logged if the directory is not empty.","Example","rootDirectory = "/usb1/"","tempDirectoryName = "temp"","if fs.is_dir(rootDirectory..tempDirectoryName) == false then","    fs.mkdir(rootDirectory..tempDirectoryName)","end","fs.rmdir(rootDirectory..tempDirectoryName)","Insert a USB flash drive into the front panel of the instrument.","Set rootDirectory to be the USB port.","Set tempDirectoryName to be equivalent to temp.","Check to see if tempDirectoryName exists.","If it does not exist, create a directory named temp.","Remove the directory.","Also see","fs.mkdir()","fs.rmdir()","14815.htm"); +Page[161]=new Array("This function retrieves the local time zone.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","timeZone = gettimezone()","timeZone","The local time zone of the instrument","Details","See settimezone() for additional details about the time zone format and a description of the fields.","timeZone can be in either of the following formats:","If one parameter was used with settimezone(), the format used is:
GMThh:mm:ss","If four parameters were used with settimezone(), the format used is:
GMThh:mm:ssGMThh:mm:ss,Mmm.w.dw/hh:mm:ss,Mmm.w.dw/hh:mm:ss","Example","timezone = gettimezone()","Reads the value of the local time zone.","Also see","settimezone()","gettimezone()","15011.htm"); +Page[162]=new Array("This KIParlib factory script function performs a linear current sweep and calculates the transconductance (Gm) at each point.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","gm_array, vbuf, ibuf = gm_isweep(smu, start_i, stop_i, points)","gm_array","A Lua table containing the calculated Gm values at each point","vbuf","A reading buffer containing the measured voltage at each point","ibuf","A reading buffer containing the measured current at each point","smu","Instrument channel (for example, smua refers to SMU channel A)","start_i","Starting current level of the sweep ","stop_i","Ending current level of the sweep ","points","Number of measurements between start_i and stop_i (must be ³ 2)","Details","Output data includes transconductance values, reading buffer with measured voltages, reading buffer with measured voltages and currents.","If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.","The gm_isweep() function performs a linear current sweep, measuring voltage and current, and then calculating the transconductance (Gm) at each point using the central difference method. It can return an array of Gm values, a reading buffer with the measured voltages, and a reading buffer with the measured currents.","Example","gm_array = gm_isweep(smua, 0, 0.01, 20)","gm_array, vbuf = gm_isweep(smua, 0, 0.01, 20)","gm_array, vbuf, ibuf = gm_isweep(smua, 0,"," 0.01, 20)","Source‑measure unit (SMU) A returns Gm values only.","SMU A returns Gm and reading buffer with measured voltages.","SMU A returns Gm and reading buffers with measured voltages and currents.","Also see","gm_vsweep()","KIParlib factory script","gm_isweep()","12957.htm"); +Page[163]=new Array("This KIParlib factory script function performs a linear voltage sweep and calculates the transconductance (Gm) at each point.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","gm_array, ibuf, vbuf = gm_vsweep(smu, start_v, stop_v, points)","gm_array","A Lua table containing the calculated Gm values at each point","ibuf","A reading buffer containing the measured current at each point","vbuf","A reading buffer containing the measured voltage at each point","smu","Instrument channel (for example, smua refers to SMU channel A)","start_v","Starting voltage level of the sweep ","stop_v","Ending voltage level of the sweep ","points","Number of measurements between start_v and stop_v (must be ³ 2)","Details","Output data includes transconductance values, reading buffer with measured currents, reading buffer with measured currents and voltages.","The gm_vsweep() function performs a linear voltage sweep, measuring voltage and current, and then calculating the transconductance (Gm) at each point using the central difference method. It can return an array of Gm values, a reading buffer with the measured currents, and a reading buffer with the measured voltages.","Example","gm_array = gm_vsweep(smua, 0, 5, 20)","gm_array, ibuf = gm_vsweep(smua, 0, 5, 20)","gm_array, ibuf, vbuf = gm_vsweep(smua, 0, 5, 20)","SMU A returns Gm values only.","SMU A returns Gm and reading buffer with measured currents.","SMU A returns Gm and reading buffers with measured currents and voltages.","Also see","gm_isweep()","KIParlib factory script","gm_vsweep()","12955.htm"); +Page[164]=new Array("This attribute contains the GPIB address.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","No","Not applicable","Nonvolatile memory","26","Usage","address = gpib.address","gpib.address = address","address","The GPIB address of the instrument (1 to 30)","Details","The address can be set to any address value from 1 to 30. However, the address must be unique in the system. It cannot conflict with an address that is assigned to another instrument or to the GPIB controller.","A new GPIB address takes effect when the command to change it is processed. If there are response messages in the output queue when this command is processed, they must be read at the new address.","If command messages are being queued (sent before this command has executed), the new settings may take effect in the middle of a subsequent command message, so care should be exercised when setting this attribute from the GPIB interface.","You should allow sufficient time for the command to be processed before attempting to communicate with the instrument again.","The reset() function does not affect the GPIB address.","Example","gpib.address = 26","address = gpib.address","print(address)","Sets the GPIB address and reads the address.","Output:","26","Also see","None","gpib.address","14860.htm"); +Page[165]=new Array("This KIHighC factory script function performs a current leakage measurement after stepping the output voltage.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","imeas = i_leakage_measure(smua, levelv, limiti, sourcedelay, measurei, measuredelay)","imeas","The measured current","levelv","Voltage level to step to when this function is called","limiti","Current limit setting for the voltage step","sourcedelay","Delay to wait before lowering the current limit for measurement","measurei","Current limit (and measure range); note the current limit is lower at this level and because high-capacitance mode is active, the measure range will follow","measuredelay","Delay to wait after lowering the current limit before taking the measurement","Details","This function causes the SMU to:","Change its current limit to limiti with a voltage output of levelv for sourcedelay time, and then change its current limit to measurei (that also changes the measurement range to measurei) for measuredelay time ","When measuredelay time expires, a measurement is made and returned as imeas","When measuring leakage current:","Charge the capacitor before calling this function (the output of the instrument is usually at a nonzero voltage before calling this function; when measuring leakage, this function does not charge the capacitor)","Set levelv = 0","Example","smua.source.highc = smua.ENABLE","smua.source.levelv = 5","smua.source.output = smua.OUTPUT_ON","delay(1)","imeas = i_leakage_measure(smua, 0, 1, 300e-3, 10e-6, 0.1)","Enable high-capacitance mode. Charge the capacitor at 5 V for 1 second set
by delay(1).","The parameters passed on to the i_leakage_measure() function in this example are:","smu = smua","levelv = 0 V","limiti = 1 A","sourcedelay = 300 ms","measurei = 10 µA range","measuredelay = 100 ms","The levels and delays depend on the value and type of capacitor used.","Also see","i_leakage_threshold()","High-capacitance mode","KIHighC factory script","i_leakage_measure()","12951.htm"); +Page[166]=new Array("This KIHighC factory script function measures the current and compares it to a threshold. This continues until either the measured current drops below the threshold or the timeout expires.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","f = i_leakage_threshold(smua, levelv, limiti, sourcedelay, measurei, measuredelay, threshold, timeout)","f","A Boolean flag; this flag is true when the current is below the threshold, false if threshold is not reached before timeout expires","levelv","Voltage level to step to when this function is called","limiti","Current limit setting for the voltage step","sourcedelay","Delay to wait before lowering the current limit for measurement","measurei","Current limit (and measure range); note the current limit is lower at this level and because high-capacitance mode is active, the measure range will follow","measuredelay","Delay before the first measurement after measure range is changed","threshold","The specified current that establishes the test limit","timeout","Amount of time (in seconds) to wait for the current to drop to threshold after all the delays have occurred","Details","This function causes the SMU to:","Change its current limit to limiti with a voltage output of levelv for sourcedelay time, and then changes its current limit to measurei (that also changes the measurement range to measurei) for measuredelay time. ","When measuredelay time expires, measurements are taken at a rate determined by the smua.measure.nplc setting.","When testing the leakage current threshold:","Charge the capacitor before calling this function. The output of the instrument is usually at a non-zero voltage before calling this function; when measuring leakage, this function does not charge the capacitor.","If testing the leakage current threshold of the device, set levelv = 0.","Example","smua.source.highc = smua.ENABLE","smua.source.levelv = 5","smua.source.output = smua.OUTPUT_ON","delay(1)","pass = i_leakage_threshold(smua, 0, 1, 300e-3, 10e-6, 100e-3, 1e-6, 1)","Enable high-capacitance mode.","Charge the capacitor. ","The parameters passed on to the i_threshold_measure() function in this example are:","smu = smua","levelv = 0 V","limiti = 1 A","sourcedelay = 300 ms","measurei = 10 µA range","measuredelay = 100 ms","threshold = 1 µA","timeout = 1 s","The levels and delays depend on the value and type of capacitor used.","Sets pass = true if the current is measured below 1 µA in less than 1 second.","Also see","High-capacitance mode","i_leakage_measure()","High-capacitance mode","KIHighC factory script","i_leakage_threshold()","12953.htm"); +Page[167]=new Array("This function closes a file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes (see Details)","Usage","io.close()","io.close(file)","file","The descriptor of the file to close","Details","If a file is not specified, the default output file closes.","Only io.close(), used without specifying a parameter, can be accessed from a remote node.","Example","testFile, testError = io.open("testfile.txt", "w")","if nil == testError then"," testFile:write("This is my test file")"," io.close(testFile)","end","Opens file testfile.txt for writing. If no errors were found while opening, writes "This is my test file" and closes the file.","Also see","io.open()","io.close()","14868.htm"); +Page[168]=new Array("This function saves buffered data to a file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","io.flush()","Details","You must use the io.flush() or io.close() functions to write data to the file system.","@Data is not automatically written to a file when you use the io.write() function. The io.write() function buffers data; it may not be written to the USB flash drive immediately. Use the io.flush() function to immediately write buffered data to the drive.","This function only flushes the default output file.","Using this command removes the need to close a file after writing to it and allows it to be left open to write more data. Data may be lost if the file is not closed or flushed before an application ends. To prevent the loss of data if there is going to be a time delay before more data is written (and when you want to keep the file open and not close it), flush the file after writing to it.","Also see","fileVar:flush()","fileVar:write()","io.write()","io.flush()","14870.htm"); +Page[169]=new Array("This function assigns a previously opened file, or opens a new file, as the default input file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes (see Details)","Usage","fileVar = io.input()","fileVar = io.input("newfile")","fileVar","The descriptor of the input file or an error message (if the function fails)","newfile","A string representing the path of a file to open as the default input file, or the file descriptor of an open file to use as the default input file","Details","The newfile path may be absolute or relative to the current working directory.","When using this function from a remote TSP-Link® node, this command does not accept a file descriptor and does not return a value.","If the function fails, an error message is returned.","Also see","io.open()","io.output()","io.input()","66560.htm"); +Page[170]=new Array("This function opens a file for later reference.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","fileVar, errorMsg = io.open("path")","fileVar, errorMsg = io.open("path", "mode")","fileVar","The descriptor of the opened file","errorMsg","Indicates whether an error was encountered while processing the function","path","The path of the file to open","mode","A string representing the intended access mode ("r" = read, "w" = write, and "a" = append)","Details","The path to the file to open may be absolute or relative to the current working directory. If you successfully open the file, errorMsg is nil and fileVar has the descriptor that can be used to access the file.","If an error is encountered, the command returns nil for fileVar and an error string.","Example","testFile, testError = io.open("testfile.txt", "w")","if testError == nil then"," testFile:write("This is my test file")"," io.close(testFile)","end","Opens file testfile.txt for writing. If no errors were found while opening, writes "This is my test file" and closes the file.","Also see","io.close()","io.open()","14872.htm"); +Page[171]=new Array("This function assigns a previously opened file or opens a new file as the default output file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes (see Details)","Usage","fileVar = io.output()","fileVar = io.output("newfile")","fileVar","The descriptor of the output file or an error message (if the function fails)","newfile","A file descriptor to assign (or the path of a file to open) as the default output file","Details","The path of the file to open may be absolute or relative to the current working directory.","When accessed from a remote node using the TSP-Link network, this command does not accept a file descriptor parameter and does not return a value.","If the function fails, an error message is returned.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","errorqueue.clear()","print("\\n*** io.output")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1")","myfile:close()","do","fileHandle = io.output(fileName)","print(fileHandle)","end","io.close(fileHandle)","print(fileHandle)","os.remove(fileName)","Assign the file to be the default output file.","Also see","io.input()","io.open()","io.output()","14873.htm"); +Page[172]=new Array("This function reads data from the default input file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","data1 = io.read()","data1 = io.read("format1")","data1, data2 = io.read("format1", "format2")","data1, ..., dataN = io.read("format1", ..., "formatN")","data1","The data read from the file","data2","The data read from the file","dataN","The data read from the file; the number of return values matches the number of format values given","format1","A string or number indicating the type of data to be read","format2","A string or number indicating the type of data to be read","formatN","A string or number indicating the type of data to be read","...","One or more entries (or values) separated by commas","Details","The format parameters may be any of the following:","Format parameter","Description",""*n"","Returns a number",""*a"","Returns the whole file, starting at the present position; returns an empty string if it is at the end of file",""*l"","Returns the next line, skipping the end of line; returns nil if the present file position is at the end of file","N","Returns a string with up to N characters; returns an empty string if N is zero (0); returns nil if the present file position is at the end of file","Any number of format parameters may be passed to this command, each corresponding to a returned data value.","If no format parameters are provided, the function will perform as if the function was passed the value "*l".","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","errorqueue.clear()","-- io.read","print("\\n*** io.read")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1\\n")","myfile:flush()","myfile:close()","do","fileHandle = io.input(fileName)","value = io.read("*a")","print(value)","end","fileHandle:close()","print(errorqueue.next())","Read data from the default input file.","Also see","None","io.read()","14874.htm"); +Page[173]=new Array("This function checks whether or not a given object is a file handle.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","type = io.type(obj)","type","Indicates whether the object is an open file handle","obj","Object to check","Details","Returns the string "file" if the object is an open file handle. If it is not an open file handle, nil is returned.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","errorqueue.clear()","print("\\n*** io.type")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1")","myfile:close()","do","fileHandle = io.output(fileName)","state = io.type(fileHandle)","print(state)","end","io.close(fileHandle)","local state = io.type(fileHandle)","print(state)","os.remove(fileName)","Check whether or not fileName is a file handle.","Also see","io.open()","io.type()","14875.htm"); +Page[174]=new Array("This function writes data to the default output file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","io.write()","io.write(data1)","io.write(data1, data2)","io.write(data1, ..., dataN)","data1","The data to be written","data2","The data to be written","dataN","The data to be written","...","One or more values separated by commas","Details","All data parameters must be either strings or numbers.","@Data is not immediately written to a file when you use the io.write() function. The io.write() function buffers data; it may not be written to the USB flash drive immediately. Use the io.flush() function to immediately write buffered data to the drive.","Example","local fileName = "/usb1/myfile.txt"","if fs.is_file(fileName) then"," os.remove(fileName)"," print("Removing file")","else"," print("Nothing removed")","end","errorqueue.clear()","print("\\n*** io.write")","myfile, myfile_err, myfile_errnum = io.open(fileName, "w")","myfile:write("Line 1")","myfile:close()","do","fileHandle = io.output(fileName)","io.write("Line 2")","end","io.close(fileHandle)","os.remove(fileName)","Writes data to the default output file.","Also see","io.flush()","io.write()","14877.htm"); +Page[175]=new Array("This function re-initializes the LAN interface with new settings.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","lan.applysettings()","Details","Disconnects all existing LAN connections to the instrument and re-initializes the LAN with the present configuration settings.","This function initiates a background operation. LAN configuration could be a lengthy operation. Although the function returns immediately, the LAN initialization continues to run in the background.","Even though the LAN configuration settings may not have changed since the LAN was last connected, new settings may take effect due to the dynamic nature of dynamic host configuration protocol (DHCP) or dynamic link local addressing (DLLA) configuration.","Re-initialization takes effect even if the configuration has not changed since the last time the instrument connected to the LAN.","Example","lan.applysettings()","Re-initialize the LAN interface with new settings.","Also see","None","lan.applysettings()","14890.htm"); +Page[176]=new Array("This attribute is used to enable or disable link monitoring.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","1 (lan.ENABLE)","Usage","state = lan.autoconnect","lan.autoconnect = state","state","LAN link monitoring state:","1 or lan.ENABLE: Enables automatic link reconnection and monitoring","0 or lan.DISABLE: Disables automatic link reconnection and monitoring","Details","This attribute sets the LAN link monitoring and automatic connection state.","When this is set to lan.ENABLE, all connections are closed if the link to the LAN is lost for more than the time specified by lan.linktimeout.","Set this attribute to lan.ENABLE to automatically reset the LAN connection after the LAN link is established.","Example","lan.autoconnect = lan.ENABLE","Enable LANK link monitoring.","Also see","lan.linktimeout","lan.restoredefaults()","lan.autoconnect","14891.htm"); +Page[177]=new Array("Configures DNS server IP addresses.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory",""0.0.0.0"","Usage","dnsAddress = lan.config.dns.address[N]","lan.config.dns.address[N] = "dnsAddress"","dnsAddress","DNS server IP address","N","Entry index (1 or 2)","Details","This attribute is an array of DNS (domain name system) server addresses. These addresses take priority for DNS lookups and are consulted before any server addresses that are obtained using DHCP. This allows local DNS servers to be specified that take priority over DHCP‑configured global DNS servers.","You can specify up to two addresses. The address specified by 1 is consulted first for DNS lookups. dnsAddress must be a string specifying the IP address of the DNS server in dotted decimal notation.","Unused entries are returned as "0.0.0.0" when read. To disable an entry, set its value to "0.0.0.0" or the empty string "".","Although only two addresses may be manually specified here, the instrument will use up to three DNS server addresses. If two are specified here, only one that is given by a DHCP server is used. If no entries are specified here, up to three addresses that are given by a DHCP server are used.","Example","dnsaddress = "164.109.48.173"","lan.config.dns.address[1] = dnsaddress","Set the DNS address 1 to "164.109.48.173"","Also see","lan.config.dns.domain","lan.config.dns.dynamic","lan.config.dns.hostname","lan.config.dns.verify","lan.restoredefaults()","lan.config.dns.address[N]","14898.htm"); +Page[178]=new Array("Configures the dynamic DNS domain.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","""","Usage","domain = lan.config.dns.domain","lan.config.dns.domain = "domain"","domain","Dynamic DNS registration domain; use a string of 255 characters or less","Details","This attribute holds the domain to request during dynamic DNS registration. Dynamic DNS registration works with DHCP to register the domain specified in this attribute with the DNS server.","The length of the fully qualified host name (combined length of the domain and host name with separator characters) must be less than or equal to 255 characters. Although up to 255 characters are allowed, you must make sure the combined length is also no more than 255 characters.","Example","print(lan.config.dns.domain)","Outputs the present dynamic DNS domain. For example, if the domain is "Matrix", the response would be:","Matrix","Also see","lan.config.dns.dynamic","lan.config.dns.hostname","lan.config.dns.verify","lan.restoredefaults()","lan.config.dns.domain","14899.htm"); +Page[179]=new Array("Enables or disables the dynamic DNS registration.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","1 (lan.ENABLE)","Usage","state = lan.config.dns.dynamic","lan.config.dns.dynamic = state","state","The dynamic DNS registration state. It may be one of the following values:","1 or lan.ENABLE: Enabled","0 or lan.DISABLE: Disabled","Details","Dynamic DNS registration works with DHCP to register the host name with the DNS server. The host name is specified in the lan.config.dns.hostname attribute.","Example","print(lan.config.dns.dynamic)","Outputs the dynamic registration state.","If dynamic DNS registration is enabled, the response is:","1.00000e+00","Also see","lan.config.dns.hostname","lan.restoredefaults()","lan.config.dns.dynamic","14900.htm"); +Page[180]=new Array("This attribute defines the dynamic DNS host name.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","Instrument specific (see Details)","Usage","hostName = lan.config.dns.hostname","lan.config.dns.hostname = "hostName"","hostName","The host name to use for dynamic DNS registration; the host name must:","be a string of 63 characters or less","start with a letter","end with a letter or digit","contain only letters, digits, and hyphens","Details","This attribute holds the host name to request during dynamic DNS registration. Dynamic DNS registration works with DHCP to register the host name specified in this attribute with the DNS server.","The factory default value for hostName is "k‑<model number>‑<serial number>", where <model number> and <serial number> are replaced with the actual model number and serial number of the instrument (for example, "k‑2601B-PULSE‑1234567"). Note that hyphens separate the characters of hostName. ","The length of the fully qualified host name (combined length of the domain and host name with separator characters) must be less than or equal to 255 characters. Although up to 63 characters can be entered here, care must be taken to be sure the combined length is no more than 255 characters.","Setting this attribute to an empty string (in other words, setting this attribute to a string of length zero, or one consisting entirely of whitespace characters) will revert the host name to the factory default value.","Example","print(lan.config.dns.hostname)","Outputs the present dynamic DNS host name.","Also see","lan.config.dns.domain","lan.config.dns.dynamic","lan.restoredefaults()","lan.config.dns.hostname","66559.htm"); +Page[181]=new Array("This attribute defines the DNS host name verification state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","1 (lan.ENABLE)","Usage","state = lan.config.dns.verify","lan.config.dns.verify = state","state","DNS hostname verification state:","1 or lan.ENABLE: DNS host name verification enabled","0 or lan.DISABLE: DNS host name verification disabled","Details","When this is enabled, the instrument performs DNS lookups to verify that the DNS host name matches the value specified by lan.config.dns.hostname.","Example","print(lan.config.dns.verify)","Outputs the present DNS host name verification state.","If it is enabled, the output is:","1.00000e+00","Also see","lan.config.dns.hostname","lan.restoredefaults()","lan.config.dns.verify","14902.htm"); +Page[182]=new Array("This attribute defines the LAN duplex mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","1 (lan.FULL)","Usage","duplex = lan.config.duplex","lan.config.duplex = duplex","duplex","LAN duplex setting can be one of the following values:","1 or lan.FULL: Selects full-duplex operation","0 or lan.HALF: Selects half-duplex operation","Details","This attribute does not indicate the actual setting currently in effect. Use the lan.status.duplex attribute to determine the present operating state of the LAN.","Example","lan.config.duplex = lan.FULL","Select the LAN duplex mode to full.","Also see","lan.restoredefaults()","lan.config.duplex","14903.htm"); +Page[183]=new Array("This attribute contains the LAN default gateway address.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory",""0.0.0.0"","Usage","gatewayAddress = lan.config.gateway","lan.config.gateway = "gatewayAddress"","gatewayAddress","LAN default gateway address; must be a string specifying the default gateway’s IP address in dotted decimal notation","Details","This attribute specifies the default gateway IP address to use when manual or DLLA configuration methods are used to configure the LAN. If DHCP is enabled, this setting is ignored.","This attribute does not indicate the actual setting that is presently in effect. Use the lan.status.gateway attribute to determine the present operating state of the LAN.","The IP address must be formatted in four groups of numbers, each separated by a decimal.","Example","print(lan.config.gateway)","Outputs the default gateway address. For example, you might see the output:","192.168.0.1","Also see","lan.restoredefaults()","lan.status.gateway","lan.config.gateway","14904.htm"); +Page[184]=new Array("This command specifies the LAN IP address.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory",""192.168.0.2"","Usage","ipAddress = lan.config.ipaddress","lan.config.ipaddress = "ipAddress"","ipAddress","LAN IP address; must be a string specifying the IP address in dotted decimal notation","Details","This command specifies the LAN IP address to use when the LAN is configured using the manual configuration method. This setting is ignored when DLLA or DHCP is used. ","This attribute does not indicate the actual setting that is presently in effect. Use the lan.status.ipaddress attribute to determine the present operating state of the LAN.","Example","ipaddress = lan.config.ipaddress","Retrieves the presently set LAN IP address.","Also see","lan.restoredefaults()","lan.status.ipaddress","lan.config.ipaddress","14905.htm"); +Page[185]=new Array("This attribute contains the LAN settings configuration method.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","0 (lan.AUTO)","Usage","method = lan.config.method","lan.config.method = method","method","The method for configuring LAN settings; it can be one of the following values:","0 or lan.AUTO: Selects automatic sequencing of configuration methods","1 or lan.MANUAL: Use only manually specified configuration settings","Details","This attribute controls how the LAN IP address, subnet mask, default gateway address, and DNS server addresses are determined.","When method is lan.AUTO, the instrument first attempts to configure the LAN settings using dynamic host configuration protocol (DHCP). If DHCP fails, it tries dynamic link local addressing (DLLA). If DLLA fails, it uses the manually specified settings.","When method is lan.MANUAL, only the manually specified settings are used. Neither DHCP nor DLLA are attempted.","Example","print(lan.config.method)","Outputs the current method.","For example:","1.00000e+00","Also see","lan.restoredefaults()","lan.config.method","14906.htm"); +Page[186]=new Array("This attribute contains the LAN speed used when restarting in manual configuration mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","100 (100 Mbps)","Usage","speed = lan.config.speed","lan.config.speed = speed","speed","LAN speed setting in Mbps (10 or 100)","Details","This attribute stores the speed that will be used if the LAN is restarted for manual configuration operation.","This attribute does not indicate the actual setting presently in effect. Use the lan.status.speed attribute to determine the present operating state of the LAN.","The LAN speed is measured in megabits per second (Mbps).","Example","lan.config.speed = 100","Configure LAN speed for 100.","Also see","lan.restoredefaults()","lan.status.speed","lan.config.speed","14907.htm"); +Page[187]=new Array("This attribute contains the LAN subnet mask.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory",""255.255.255.0"","Usage","mask = lan.config.subnetmask","lan.config.subnetmask = "mask"","mask","String that specifies the LAN subnet mask value in dotted decimal notation","Details","This attribute specifies the LAN subnet mask that will be used when the manual configuration method is used to configure the LAN. This setting is ignored when DLLA or DHCP is used.","This attribute does not indicate the actual setting presently in effect. Use the lan.status.subnetmask attribute to determine the present operating state of the LAN.","Example","print(lan.config.subnetmask)","Outputs the LAN subnet mask, such as:","255.255.255.0","Also see","lan.restoredefaults()","lan.status.subnetmask","lan.config.subnetmask","14908.htm"); +Page[188]=new Array("This attribute contains the LAN link timeout period.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","20 (20 s)","Usage","timeout = lan.linktimeout ","lan.linktimeout = timeout","timeout","The LAN link monitor time-out period (in seconds)","Details","You must enable the command lan.autoconnect before you can use this attribute.","The timeout value represents the amount of time that passes before the instrument disconnects from the LAN due to the loss of the LAN link integrity.","The LAN interface does not disconnect if the connection to the LAN is reestablished before the timeout value expires.","If the LAN link integrity is not restored before the timeout value expires, the instrument begins to monitor for a new connection.","Example","print(lan.linktimeout)","Outputs the present LAN link timeout setting.","Also see","lan.autoconnect","lan.restoredefaults()","lan.linktimeout","14892.htm"); +Page[189]=new Array("This attribute contains the LXI domain.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","0","Usage","domain = lan.lxidomain","lan.lxidomain = domain","domain","The LXI domain number (0 to 255)","Details","This attribute sets the LXI domain number.","All outgoing LXI packets are generated with this domain number. All inbound LXI packets are ignored unless they have this domain number.","Example","print(lan.lxidomain)","Displays the LXI domain.","Also see","None","lan.lxidomain","14893.htm"); +Page[190]=new Array("This attribute controls the state of the LAN Nagle algorithm.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Power cycle","Not saved","0 (lan.DISABLE)","Usage","state = lan.nagle","lan.nagle = state","state","The state of the Nagle algorithm:","1 or lan.ENABLE: Enable the LAN Nagle algorithm for TCP connections","0 or lan.DISABLE: Disable the Nagle algorithm for TCP connections","Details","This attribute enables or disables the use of the LAN Nagle algorithm on transmission control protocol (TCP) connections.","Also see","lan.restoredefaults()","lan.nagle","14894.htm"); +Page[191]=new Array("This function resets the LAN interface.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","lan.reset()","Details","This function resets the LAN interface. It performs the commands lan.restoredefaults() and lan.applysettings().","Also see","lan.applysettings()","lan.restoredefaults()","lan.reset()","14895.htm"); +Page[192]=new Array("This function resets LAN settings to default values.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","lan.restoredefaults()","Details","The settings that are restored are shown in the following table.","Settings that are restored to default","Attribute","Default setting","lan.autoconnect","lan.ENABLE","lan.config.dns.address[N]",""0.0.0.0"","lan.config.dns.domain","""","lan.config.dns.dynamic","lan.ENABLE","lan.config.dns.hostname",""K-<model number>-<serial number>"","lan.config.dns.verify","lan.ENABLE","lan.config.duplex","lan.FULL","lan.config.gateway",""0.0.0.0"","lan.config.ipaddress",""0.0.0.0"","lan.config.method","lan.AUTO","lan.config.speed","100","lan.config.subnetmask",""255.255.255.0"","lan.linktimeout","20 (seconds)","lan.lxidomain","0","lan.nagle","lan.DISABLE","lan.timedwait","20 (seconds)","This command is run when lan.reset() is sent.","Example","lan.restoredefaults()","Restores the LAN defaults.","Also see","lan.reset()","localnode.password","lan.restoredefaults()","14896.htm"); +Page[193]=new Array("This attribute contains the DNS server IP addresses.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","dnsAddress = lan.status.dns.address[N]","dnsAddress","DNS server IP address","N","Entry index (1, 2, or 3)","Details","This attribute is an array of DNS server addresses. The instrument can use up to three addresses.","Unused or disabled entries are returned as "0.0.0.0" when read. The dnsAddress returned is a string specifying the IP address of the DNS server in dotted decimal notation.","You can only specify two addresses manually. However, the instrument uses up to three DNS server addresses. If two are specified, only the one given by a DHCP server is used. If no entries are specified, up to three address given by a DHCP server are used.","The value of lan.status.dns.address[1] is referenced first for all DNS lookups. The values of lan.status.dns.address[2] and lan.status.dns.address[3] are referenced second and third, respectively.","Example","print(lan.status.dns.address[1])","Outputs DNS server address 1, for example:","164.109.48.173","Also see","lan.status.dns.name","lan.status.dns.address[N]","14909.htm"); +Page[194]=new Array("This attribute contains the present DNS fully qualified host name.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","hostName = lan.status.dns.name","hostName","Fully qualified DNS host name that can be used to connect to the instrument","Details","A fully qualified domain name (FQDN), sometimes referred to as an absolute domain name, is a domain name that specifies its exact location in the tree hierarchy of the Domain Name System (DNS).","A FQDN is the complete domain name for a specific computer or host on the LAN. The FQDN consists of two parts: the host name and the domain name.","If the DNS host name for an instrument is not found, this attribute stores the IP address in dotted decimal notation.","Example","print(lan.status.dns.name)","Outputs the dynamic DNS host name.","Also see","lan.config.dns.address[N]","lan.config.dns.hostname","lan.status.dns.name","14910.htm"); +Page[195]=new Array("This attribute contains the duplex mode presently in use by the LAN interface.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","duplex = lan.status.duplex","duplex","LAN duplex setting can be one of the following values:","0 or lan.HALF: half-duplex operation","1 or lan.FULL: full-duplex operation","Example","print(lan.status.duplex)","Outputs the present LAN duplex mode, such as:","1.00000e+00","Also see","None","lan.status.duplex","14911.htm"); +Page[196]=new Array("This attribute contains the gateway address presently in use by the LAN interface.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","gatewayAddress = lan.status.gateway","gatewayAddress","LAN gateway address presently being used","Details","The value of gatewayAddress is a string that indicates the IP address of the gateway in dotted decimal notation.","Example","print(lan.status.gateway)","Outputs the gateway address, such as:","192.168.0.1","Also see","lan.config.gateway","lan.status.gateway","14912.htm"); +Page[197]=new Array("This attribute contains the LAN IP address presently in use by the LAN interface.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","ipAddress = lan.status.ipaddress","ipAddress","LAN IP address specified in dotted decimal notation","Details","The IP address is a character string that represents the IP address assigned to the instrument.","Example","print(lan.status.ipaddress)","Outputs the LAN IP address currently in use, such as:","192.168.0.2","Also see","lan.config.ipaddress","lan.status.ipaddress","14913.htm"); +Page[198]=new Array("This attribute contains the LAN MAC address.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","macAddress = lan.status.macaddress","macAddress","The instrument MAC address","Details","The MAC address is a character string representing the MAC address of the instrument in hexadecimal notation. The string includes colons that separate the address octets (see Example).","Example","print(lan.status.macaddress)","Outputs the MAC address of the instrument, for example:","08:00:11:00:00:57","Also see","None","lan.status.macaddress","14914.htm"); +Page[199]=new Array("This attribute contains the LAN dead socket termination port number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","port = lan.status.port.dst","port","Dead socket termination socket port number","Details","This attribute holds the TCP port number used to reset all other LAN socket connections.","To reset all LAN connections, open a connection to the DST port number.","Example","print(lan.status.port.dst)","Outputs the LAN dead socket termination port number, such as:","5.03000e+03","Also see","None","lan.status.port.dst","14915.htm"); +Page[200]=new Array("This attribute contains the LAN raw socket connection port number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","port = lan.status.port.rawsocket","port","Raw socket port number","Details","The TCP port number used to connect the instrument and to control the instrument over a raw socket communication interface.","Example","print(lan.status.port.rawsocket)","Outputs the LAN raw socket port number, such as:","5.02500e+03","Also see","None","lan.status.port.rawsocket","14916.htm"); +Page[201]=new Array("This attribute contains the LAN Telnet connection port number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","port = lan.status.port.telnet","port","Telnet port number","Details","This attribute holds the TCP port number used to connect to the instrument to control it over a Telnet interface.","Example","print(lan.status.port.telnet)","Get the LAN Telnet connection port number.","Output:","2.30000e+01","Also see","None","lan.status.port.telnet","14917.htm"); +Page[202]=new Array("This attribute contains the LAN VXI-11 connection port number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","port = lan.status.port.vxi11","port","LAN VXI-11 port number","Details","This attribute stores the TCP port number used to connect to the instrument over a VXI-11 interface.","Example","print(lan.status.port.vxi11)","Outputs the VXI-11 number, such as:","1.02400e+03","Also see","None","lan.status.port.vxi11","14918.htm"); +Page[203]=new Array("This attribute contains the LAN speed.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","speed = lan.status.speed","speed","LAN speed in Mbps, either 10 or 100","Details","This attribute indicates the transmission speed currently in use by the LAN interface.","Example","print(lan.status.speed)","Outputs the transmission speed of the instrument presently in use, such as:","1.00000e+02","Also see","None","lan.status.speed","14919.htm"); +Page[204]=new Array("This attribute contains the LAN subnet mask that is presently in use by the LAN interface.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","mask = lan.status.subnetmask","mask","A string specifying the subnet mask in dotted decimal notation","Details","Use this attribute to determine the present operating state of the LAN. This attribute will return the present LAN subnet mask value if the LAN is manually configured, or when DLLA or DHCP is used.","Example","print(lan.status.subnetmask)","Outputs the subnet mask of the instrument that is presently in use, such as:","255.255.255.0","Also see","lan.config.subnetmask","lan.status.subnetmask","14920.htm"); +Page[205]=new Array("This attribute contains the LAN timed-wait state interval.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","LAN restore defaults","Nonvolatile memory","20 (20 s)","Usage","timeout = lan.timedwait","lan.timedwait = timeout","timeout","The LAN timed-wait state interval in seconds","Details","This attribute controls the amount of time that resources are allocated to closed TCP connections. When a TCP connection is closed, the connection is put in a timed-wait state and resources remain allocated for the connection until the timed-wait state ends. During the timed-wait interval, the instrument processes delayed packets that arrive after the connection is closed.","Use this attribute to tailor the timed-wait state interval for the instrument.","Example","lan.timedwait = 30","Set the amount of time resources are allocated to TCP connection to 30 s.","Also see","lan.restoredefaults()","lan.timedwait","14897.htm"); +Page[206]=new Array("This function simulates the occurrence of the trigger and generates the corresponding event ID.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","lan.trigger[N].assert()","N","The LAN event number (1 to 8)","Details","Generates and sends a LAN trigger packet for the LAN event number specified.","Sets the pseudo line state to the appropriate state.","The following indexes provide the listed LXI events:","1:LAN0","2:LAN1","3:LAN2","…","8:LAN7","Example","lan.trigger[5].assert()","Creates a trigger with LAN packet 5.","Also see","lan.lxidomain","lan.trigger[N].clear()","lan.trigger[N].mode","lan.trigger[N].overrun","lan.trigger[N].stimulus","lan.trigger[N].wait()","Understanding hardware value and pseudo line state","lan.trigger[N].assert()","14921.htm"); +Page[207]=new Array("This function clears the event detector for a LAN trigger.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","lan.trigger[N].clear()","N","The LAN event number (1 to 8) to clear","Details","The trigger event detector enters the detected state when an event is detected. This function clears a trigger event detector and discards the history of the trigger packet.","This function clears all overruns associated with this LAN trigger.","Example","lan.trigger[5].clear()","Clears the event detector with LAN packet 5.","Also see","lan.trigger[N].assert()","lan.trigger[N].overrun","lan.trigger[N].stimulus","lan.trigger[N].wait()","lan.trigger[N].clear()","14922.htm"); +Page[208]=new Array("This function prepares the event generator for outgoing trigger events.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","lan.trigger[N].connect()","N","The LAN event number (1 to 8)","Details","This command prepares the event generator to send event messages. For TCP connections, this opens the TCP connection.","The event generator automatically disconnects when either the protocol or IP address for this event is changed.","Example","lan.trigger[1].protocol = lan.MULTICAST","lan.trigger[1].connect()","lan.trigger[1].assert()","Set the protocol for LAN trigger 1 to be multicast when sending LAN triggers. Then, after connecting the LAN trigger, send a message on LAN trigger 1 by asserting it.","Also see","lan.trigger[N].assert()","lan.trigger[N].ipaddress","lan.trigger[N].overrun","lan.trigger[N].protocol","lan.trigger[N].stimulus","lan.trigger[N].wait()","lan.trigger[N].connect()","14923.htm"); +Page[209]=new Array("This attribute stores the LAN event connection state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","connected = lan.trigger[N].connected","connected","The LAN event connection state:","true: Connected","false: Not connected","N","The LAN event number (1 to 8)","Details","This read-only attribute is set to true when the LAN trigger is connected and ready to send trigger events following a successful lan.trigger[N].connect() command; if the LAN trigger is not ready to send trigger events, this value is false.","This attribute is also false when either lan.trigger[N].protocol or lan.trigger[N].ipaddress attributes are changed or the remote connection closes the connection.","Example","lan.trigger[1].protocol = lan.MULTICAST","print(lan.trigger[1].connected)","Outputs true if connected, or false if not connected.","Example output:","false","Also see","lan.trigger[N].connect()","lan.trigger[N].ipaddress","lan.trigger[N].protocol","lan.trigger[N].connected","14924.htm"); +Page[210]=new Array("This function disconnects the LAN trigger.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","lan.trigger[N].disconnect()","N","The LAN event number (1 to 8)","Details","For TCP connections, this closes the TCP connection.","The LAN trigger automatically disconnects when either the lan.trigger[N].protocol or lan.trigger[N].ipaddress attributes for this event are changed.","Also see","lan.trigger[N].ipaddress","lan.trigger[N].protocol","lan.trigger[N].disconnect()","14925.htm"); +Page[211]=new Array("This constant is the event identifier used to route the LAN trigger to other subsystems (using stimulus properties).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","lan.trigger[N].EVENT_ID","N","The LAN event number (1 to 8)","Details","Set the stimulus of any trigger event detector to the value of this constant to have it respond to incoming LAN trigger packets.","Example","digio.trigger[14].stimulus = lan.trigger[1].EVENT_ID","Route occurrences of triggers on LAN trigger 1 to digital I/O trigger 14.","Also see","None","lan.trigger[N].EVENT_ID","14926.htm"); +Page[212]=new Array("This attribute specifies the address (in dotted‑decimal format) of UDP or TCP listeners.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
LAN trigger N reset
Recall setup","Not saved ",""0.0.0.0"","Usage","ipAddress = lan.trigger[N].ipaddress","lan.trigger[N].ipaddress = "ipAddress"","ipAddress","The LAN address for this attribute as a string in dotted decimal notation","N","The LAN event number (1 to 8)","Details","Sets the IP address for outgoing trigger events.","Set to "0.0.0.0" for multicast.","After changing this setting, the lan.trigger[N].connect() command must be called before outgoing messages can be sent.","Example","lan.trigger[3].protocol = lan.TCP","lan.trigger[3].ipaddress = "192.168.1.100"","lan.trigger[3].connect()","Set the protocol for LAN trigger 3 to be lan.TCP when sending LAN triggers.","Use IP address "192.168.1.100" to connect the LAN trigger.","Also see","lan.trigger[N].connect()","lan.trigger[N].ipaddress","14927.htm"); +Page[213]=new Array("This attribute sets the trigger operation and detection mode of the specified LAN event.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
LAN trigger N reset
Recall setup","Not saved","0 (lan.TRIG_EITHER)","Usage","mode = lan.trigger[N].mode","lan.trigger[N].mode = mode","mode","A number representing the trigger mode (0 to 7); see the Details section for more information","N","A number representing the LAN event number (1 to 8)","Details","This command controls how the trigger event detector and the output trigger generator operate on the given trigger. These settings are intended to provide behavior similar to the digital I/O triggers.","LAN trigger mode values","Mode ","Number","Trigger packets detected as input","LAN trigger packet generated for output with a…","lan.TRIG_EITHER","0","Rising or falling edge (positive or negative state)","negative state","lan.TRIG_FALLING","1","Falling edge (negative state)","negative state","lan.TRIG_RISING","2","Rising edge (positive state)","positive state","lan.TRIG_RISINGA","3","Rising edge (positive state)","positive state","lan.TRIG_RISINGM","4","Rising edge (positive state)","positive state","lan.TRIG_SYNCHRONOUS","5","Falling edge (negative state)","positive state","lan.TRIG_SYNCHRONOUSA","6","Falling edge (negative state)","positive state","lan.TRIG_SYNCHRONOUSM","7","Rising edge (positive state)","negative state","lan.TRIG_RISING and lan.TRIG_RISINGA are the same.","lan.TRIG_RISING and lan.TRIG_RISINGM are the same.","Use of either lan.TRIG_SYNCHRONOUSA or lan.TRIG_SYNCHRONOUSM over lan.TRIG_SYNCHRONOUS is preferred, as lan.TRIG_SYNCHRONOUS is provided for compatibility with older firmware.","Example","print(lan.trigger[1].mode)","Outputs the present LAN trigger mode of LAN event 1.","Also see","Digital I/O","TSP-Link system expansion interface","lan.trigger[N].mode","14928.htm"); +Page[214]=new Array("This attribute contains the overrun status of the LAN event detector.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","LAN trigger N clear
LAN trigger N reset
Instrument reset
Recall setup","Not applicable","Not applicable","Usage","overrun = lan.trigger[N].overrun","overrun","The trigger overrun state for the specified LAN packet (true or false)","N","The LAN event number (1 to 8)","Details","This command indicates whether an event has been ignored because the event detector was already in the detected state when the event occurred.","This is an indication of the state of the event detector built into the synchronization line itself. It does not indicate if an overrun occurred in any other part of the trigger model, or in any other construct that is monitoring the event.","It also is not an indication of an output trigger overrun. Output trigger overrun indications are provided in the status model.","Example","overrun = lan.trigger[5].overrun","print(overrun)","Checks the overrun status of a trigger on LAN5 and outputs the value, such as:","false","Also see","lan.trigger[N].assert()","lan.trigger[N].clear()","lan.trigger[N].stimulus","lan.trigger[N].wait()","lan.trigger[N].overrun","14929.htm"); +Page[215]=new Array("This attribute sets the LAN protocol to use for sending trigger messages.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
LAN trigger N reset
Recall setup","Not saved ","0 (lan.TCP)","Usage","protocol = lan.trigger[N].protocol","lan.trigger[N].protocol = protocol","protocol","The protocol to use for messages from the trigger:","0 or lan.TCP","1 or lan.UDP","2 or lan.MULTICAST","N","The LAN event number (1 to 8)","Details","The LAN trigger listens for trigger messages on all supported protocols, but uses the designated protocol for sending outgoing messages. After changing this setting, lan.trigger[N].connect() must be called before outgoing event messages can be sent.","When the lan.MULTICAST protocol is selected, the lan.trigger[N].ipaddress attribute is ignored and event messages are sent to the multicast address 224.0.23.159.","Example","print(lan.trigger[1].protocol)","Get LAN protocol to use for sending trigger messages for LAN event 1.","Also see","lan.trigger[N].connect()","lan.trigger[N].ipaddress","lan.trigger[N].protocol","14930.htm"); +Page[216]=new Array("This attribute sets the simulated line state for the LAN trigger.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
LAN trigger N reset
Recall setup","Not saved ","1","Usage","pseudostate = lan.trigger[N].pseudostate","lan.trigger[N].pseudostate = pseudostate","pseudostate","The simulated line state (0 or 1)","N","A number representing the LAN event number (1 to 8)","Details","This attribute can be set to initialize the pseudo line state to a known value.","Setting this attribute does not cause the LAN trigger to generate any events or output packets.","Example","print(lan.trigger[1].pseudostate)","Get the present simulated line state for the LAN event 1.","Also see","None","lan.trigger[N].pseudostate","14931.htm"); +Page[217]=new Array("This attribute specifies events that cause this trigger to assert.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
LAN trigger N reset
Recall setup","Not saved","0","Usage","triggerStimulus = lan.trigger[N].stimulus","lan.trigger[N].stimulus = triggerStimulus","triggerStimulus","The LAN event identifier used to trigger the event","N","A number specifying the trigger packet over the LAN for which to set or query the trigger source (1 to 8)","Details","This attribute specifies which event causes a LAN trigger packet to be sent for this trigger. Set triggerStimulus to one of the trigger event IDs, which are shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Setting this attribute to zero disables automatic trigger generation.","If any events are detected prior to calling lan.trigger[N].connect(), the event is ignored and the action overrun is set.","Example","lan.trigger[5].stimulus = trigger.timer[1].EVENT_ID","Use timer 1 trigger event as the source for LAN packet 5 trigger stimulus.","Also see","lan.trigger[N].assert()","lan.trigger[N].clear()","lan.trigger[N].connect()","lan.trigger[N].overrun","lan.trigger[N].wait()","lan.trigger[N].stimulus","17679.htm"); +Page[218]=new Array("This function waits for an input trigger.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","triggered = lan.trigger[N].wait(timeout)","triggered","Trigger detection indication (true or false)","N","The trigger packet over LAN to wait for (1 to 8)","timeout","Maximum amount of time in seconds to wait for the trigger event","Details","If one or more trigger events have been detected since the last time lan.trigger[N].wait() or lan.trigger[N].clear() was called, this function returns immediately.","After waiting for a LAN trigger event with this function, the event detector is automatically reset and rearmed regardless of the number of events detected.","Example","triggered = lan.trigger[5].wait(3)","Wait for a trigger with LAN packet 5 with a timeout of 3 seconds.","Also see","lan.trigger[N].assert()","lan.trigger[N].clear()","lan.trigger[N].overrun","lan.trigger[N].stimulus","lan.trigger[N].wait()","14933.htm"); +Page[219]=new Array("This attribute enables or disables automatic power line frequency detection at start‑up.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","true (enabled)","Usage","flag = localnode.autolinefreq","localnode.autolinefreq = flag","flag","The auto line frequency detection setting:","true: Enable automatic line frequency detection at start-up","false: Disable automatic line frequency detection at start-up","Details","When this attribute is set to true, the power line frequency is detected automatically the next time the 2601B-PULSE powers up. After the power line frequency is automatically detected at power-up, the localnode.linefreq attribute is set automatically to 50 or 60.","If the localnode.linefreq attribute is explicitly set, localnode.autolinefreq is automatically set to false.","When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].autolinefreq.","Also see","localnode.linefreq","localnode.autolinefreq","15007.htm"); +Page[220]=new Array("This attribute stores a user-defined description and mDNS service name of the instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","Instrument specific (see Details)","Usage","localnode.description = "description"","description = localnode.description","description","User-defined description and mDNS service name of the instrument; use a string of 63 characters or less","Details","This attribute stores a string that contains a description of the instrument. This value appears on LXI welcome page of the instrument. The value of this attribute is also used as the mDNS service name of the instrument.","This attribute's factory default value is "Keithley Instruments SMU <model number> - <serial number>", where <model number> and <serial number> are replaced with the actual model number and serial number of the instrument. Setting this attribute to an empty string (in other words, setting this attribute to a string of length zero, or one consisting entirely of whitespace characters) will revert the description to the factory default value.","When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].description.","Example","description = "System in Lab 05"","localnode.description = description","Set description to "System in Lab 05".","Also see","None","localnode.description","15008.htm"); +Page[221]=new Array("This attribute returns the product license agreements.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Nonvolatile memory","Not applicable","Usage","license_agreement = localnode.license","license_agreement","The text of the license agreements","Example","print(localnode.license)","Returns the license agreements for the 2601B-PULSE.","Also see","None","localnode.license","92667.htm"); +Page[222]=new Array("This attribute contains the power line frequency setting that is used for NPLC calculations.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","60 (60 Hz)","Usage","frequency = localnode.linefreq","localnode.linefreq = frequency","frequency","An integer representing the detected or specified line frequency of the instrument","Details","To achieve optimum noise rejection when performing measurements at integer NPLC apertures, set the line frequency attribute to match the frequency (50 Hz or 60 Hz) of the AC power line. ","When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].linefreq. When this attribute is set, the localnode.autolinefreq attribute is automatically set to false. You can have the instrument automatically detect the AC power line frequency and set this attribute with the line frequency detected when the instrument power is turned on by setting the localnode.autolinefreq attribute to true.","Example 1","frequency = localnode.linefreq","Reads line frequency setting.","Example 2","localnode.linefreq = 60","Sets the line frequency to 60 Hz.","Also see","localnode.autolinefreq","localnode.linefreq","15012.htm"); +Page[223]=new Array("This attribute stores the model number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","model = localnode.model","model","The model number of the instrument","Example","print(localnode.model)","Outputs the model number of the local node. For example:","2601B-PULSE","Also see","localnode.serialno","localnode.model","92703.htm"); +Page[224]=new Array("This attribute stores the remote access password.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (W)","Yes","LAN reset
LAN restore defaults","Nonvolatile memory","""","Usage","localnode.password = "password"","password","A string that contains the remote interface password","Details","This write-only attribute stores the password that is set for any remote interface. When password usage is enabled (localnode.passwordmode), you must supply a password to change the configuration or to control an instrument from a web page or other remote command interface.","The instrument continues to use the old password for all interactions until the command to change it executes. When changing the password, give the instrument time to execute the command before attempting to use the new password.","You cannot retrieve a lost password from any command interface.","You can reset the password by resetting the LAN from the front panel or by using the lan.reset() command.","When using this command from a remote node, localnode should be replaced with the node reference, for example, node[5].password.","Example","localnode.password = "N3wpa55w0rd"","Changes the remote interface password to N3wpa55w0rd.","Also see","lan.reset()","localnode.passwordmode","localnode.password","15014.htm"); +Page[225]=new Array("This attribute stores the remote access password enable mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","1 (localnode.PASSWORD_WEB)","Usage","mode = localnode.passwordmode","localnode.passwordmode = mode","mode","The remote password enable mode","Details","This attribute controls if and where remote access passwords are required. Set this attribute to one of the values below to enable password checking:","localnode.PASSWORD_NONE or 0: Disable passwords everywhere","localnode.PASSWORD_WEB or 1: Use passwords on the web interface only","localnode.PASSWORD_LAN or 2: Use passwords on the web interface and all LAN interfaces","localnode.PASSWORD_ALL or 3: Use passwords on the web interface and all remote command interfaces","When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].passwordmode.","You must also set a password.","Example","mode = localnode.PASSWORD_WEB","localnode.passwordmode = mode","localnode.password = "SMU1234"","Sets value of mode to PASSWORD_WEB.","Allows use of passwords on the web interface only.","Set the password to SMU1234.","Also see","localnode.password","localnode.passwordmode","15015.htm"); +Page[226]=new Array("This attribute determines if the instrument generates prompts in response to command messages.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Power cycle","Not saved","0 (disabled)","Usage","prompting = localnode.prompts","localnode.prompts = prompting","prompting","Prompting mode:","Do not generate prompts: 1","Generate prompts: 0","Details","When the prompting mode is enabled, the instrument generates prompts when the instrument is ready to take another command. Because the prompt is not generated until the previous command completes, enabling prompts provides handshaking with the instrument to prevent buffer overruns.","When prompting is enabled, the instrument might generate the following prompts:","TSP>. The standard prompt, which indicates that the previous command completed normally.","TSP?. The prompt that is issued if there are unread entries in the error queue when the prompt is issued. Like the TSP> prompt, it indicates that processing of the command is complete. It does not mean the previous command generated an error, only that there were still errors in the queue when the command processing was complete.",">>>>. The continuation prompt, which occurs when downloading scripts. When downloading scripts, many command messages must be sent as a group. The continuation prompt indicates that the instrument is expecting more messages as part of the present command.","Commands do not generate prompts. The instrument generates prompts in response to command completion.","Prompts are enabled or disabled only for the remote interface that is active when you send the command. For example, if you enable prompts when the LAN connection is active, they will not be enabled for a subsequent USB connection.","@
Do not disable prompting when using Test Script Builder. Test Script Builder requires prompts and sets the prompting mode automatically. If you disable prompting, the instrument will stop responding when you communicate using Test Script Builder because it is waiting for a common complete prompt from Test Script Builder.","Example","localnode.prompts = 1","Enable prompting.","Also see","localnode.showerrors","tsplink.reset()","localnode.prompts","15016.htm"); +Page[227]=new Array("This attribute enables and disables the generation of prompts for IEEE Std 488.2 common commands.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Power cycle","Not saved","1 (enabled)","Usage","prompting = localnode.prompts4882","localnode.prompts4882 = prompting","prompting","IEEE Std 488.2 prompting mode:","Disable prompting: 0","Enable prompting: 1","Details","When this attribute is enabled, the IEEE Std 488.2 common commands generate prompts if prompting is enabled with the localnode.prompts attribute. If localnode.prompts4882 is enabled, limit the number of *trg commands sent to a running script to 50 regardless of the setting of the localnode.prompts attribute.","When this attribute is disabled, IEEE Std 488.2 common commands will not generate prompts. When using the *trg command with a script that executes trigger.wait() repeatedly, disable prompting to avoid problems associated with the command interface input queue filling.","Example","localnode.prompts4882 = 0","Disables IEEE Std 488.2 common command prompting.","Also see","localnode.prompts","localnode.prompts4882","15017.htm"); +Page[228]=new Array("This function resets the local node instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","localnode.reset()","Details","If you want to reset a specific instrument or a subordinate node, use the node[X].reset() command.","A local node reset includes:","Source‑measure unit (SMU) attributes affected by a SMU reset are reset","Other settings are restored back to factory default settings","A localnode.reset() is different than a reset() because reset() resets the entire system. ","When using this command from a remote node, localnode should be replaced with the node reference, for example node[5].reset().","Example","localnode.reset()","Resets the local node.","Also see","reset()","smua.reset()","localnode.reset()","16978.htm"); +Page[229]=new Array("This attribute stores the firmware revision level.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","revision = localnode.revision","revision","Firmware revision level","Details","This attribute indicates the revision number of the firmware that is presently running in the instrument.","When using this command from a remote node, localnode should be replaced with the node reference. For example, node[5].revision.","Example","print(localnode.revision)","Outputs the present revision level.","Sample output:","1.0.0","Also see","localnode.description","localnode.model","localnode.serialno","localnode.revision","15018.htm"); +Page[230]=new Array("This attribute stores the instrument's serial number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","serialno = localnode.serialno","serialno","The serial number of the instrument","Details","This indicates the instrument serial number.","Example","display.clear()","display.settext(localnode.serialno)","Clears the instrument display.","Places the serial number of the instrument on the top line of its display.","Also see","localnode.description","localnode.model","localnode.revision","localnode.serialno","15019.htm"); +Page[231]=new Array("This attribute sets whether or not the instrument automatically sends generated errors.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Power cycle","Not saved","0 (disabled)","Usage","errorMode = localnode.showerrors","localnode.showerrors = errorMode","errorMode","Show error setting:","Show errors: 1","Do not show errors: 0","Details","If this attribute is set to 1, the instrument automatically sends any generated errors stored in the error queue, and then clears the queue. Errors are processed after executing a command message (just before issuing a prompt, if prompts are enabled).","If this attribute is set to 0, errors are left in the error queue and must be explicitly read or cleared.","When using this command from a remote node, localnode should be replaced with the node reference, for example, node[5].showerrors.","Example","localnode.showerrors = 1","Enables sending of generated errors.","Also see","localnode.prompts","localnode.showerrors","15022.htm"); +Page[232]=new Array("This function creates a function to get the value of an attribute.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","getter = makegetter(table, "attributeName")","getter","The return value","table","Read‑only table where the attribute is located","attributeName","A string representing the name of the attribute","Details","This function is useful for aliasing attributes to improve execution speed. Calling the function created with makegetter() executes more quickly than accessing the attribute directly.","Creating a getter function is only useful if it is going to be called several times. Otherwise, the overhead of creating the getter function outweighs the overhead of accessing the attribute directly.","Example","getlevel = makegetter(smua.source, "levelv")","v = getlevel()","Creates a getter function called getlevel.","When getlevel() is called, it returns the value of smua.source.levelv. ","Also see","makesetter()","makegetter()","15041.htm"); +Page[233]=new Array("This function creates a function that, when called, sets the value of an attribute.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","setter = makesetter(table, "attributeName")","setter","Function that sets the value of the attribute","table","Read-only table where the attribute is located","attributeName","The string name of the attribute","Details","This function is useful for aliasing attributes to improve execution speed. Calling the setter function execute more quickly than accessing the attribute directly.","Creating a setter function is only useful if it is going to be called several times. If you are not calling the setter function several times, it is more efficient to access the attribute directly. ","Example","setlevel = makesetter(smua.source, "levelv")for v = 1, 10 do"," setlevel(v)","end","Creates a setter function called setlevel.","Using setlevel() in the loop sets the value of smua.source.levelv, performing a source sweep.","Also see","makegetter()","makesetter()","15042.htm"); +Page[234]=new Array("This function returns the present amount of available memory and the total amount of memory in the instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","freeMem, totalMem = meminfo()","freeMem","The amount of free dynamically allocated memory available","totalMem","The total amount of dynamically allocated memory in the instrument","Details","This function returns two values:","The amount of free dynamically allocated memory available in kilobytes","The total amount of dynamically allocated memory on the instrument in kilobytes","The difference between the two values is the amount presently used.","Example","print(meminfo())","Retrieve the amount of free and total memory in the instrument.","Output:","2.89840e+04 3.27680e+04","Also see","None","meminfo()","15050.htm"); +Page[235]=new Array("This function starts test scripts from a remote node. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes (see Details)","Usage","node[N].execute("scriptCode")","N","The node number of this instrument","scriptCode","A string containing the source code","Details","Only the remote master node can use the execute command to run a script on this node. This function does not run test scripts on the master node; only on this node when initiated by the master node.","This function may only be called when the group number of the node is different than the node of the master.","This function does not wait for the script to finish execution.","This command should only be used from a remote master when controlling this instrument over a TSP-Link®.","Example 1","node[2].execute(sourcecode)","Runs script code on node 2. The code is in a string variable called sourcecode.","Example 2","node[3].execute("x = 5")","Runs script code in string constant ("x = 5") to set x","equal to 5 on node 3.","Example 3","node[32].execute(TestDut.source)","Runs the test script stored in the variable TestDut","(previously stored on the master node) on node 32.","Also see","TSP advanced features","tsplink.group","node[N].execute()","29213.htm"); +Page[236]=new Array("This function returns the value of a global variable. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","value = node[N].getglobal("name")","value","The value of the variable","N","The node number of this instrument (1 to 64)","name","The global variable name","Details","This function retrieves the value of a global variable from the runtime environment of this node.","Do not use this command to retrieve the value of a global variable from the local node. Instead, access the global variable directly. This command should only be used from a remote master when controlling this instrument over a TSP-Link network.","Example","print(node[5].getglobal("test_val"))","Retrieves and outputs the value of the global variable named test_val from node 5.","Also see","node[N].setglobal()","TSP advanced features","node[N].getglobal()","15010.htm"); +Page[237]=new Array("This function sets the value of a global variable. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","node[N].setglobal("name", value)","N","The node number of this instrument (1 to 6463)","name","The global variable name to set","value","The value to assign to the variable","Details","From a remote node, use this function to assign the given value to a global variable.","Do not use this command to create or set the value of a global variable from the local node (set the global variable directly instead). This command should only be used from a remote master when controlling this instrument over a TSP-Link network.","Example","node[3].setglobal("x", 5)","Sets the global variable x on node 3 to the value of 5.","Also see","node[N].getglobal()","TSP advanced features","node[N].setglobal()","15020.htm"); +Page[238]=new Array("This function sets the operation complete status bit when all overlapped commands are completed.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","opc()","Details","This function causes the operation complete bit in the Standard Event Status Register to be set when all previously started local overlapped commands are complete. ","Note that each node independently sets its operation complete bits in its own status model. Any nodes that are not actively performing overlapped commands set their bits immediately. All remaining nodes set their own bits as they complete their own overlapped commands.","Example","opc()","waitcomplete()","print("1")","Output:","1","Also see","Status model","waitcomplete()","opc()","15054.htm"); +Page[239]=new Array("This function deletes the file or directory with a given name.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","success, msg = os.remove("filename")","success","A success indicator (true or nil)","msg","A message value (nil or an error message)","filename","A string representing the name of the file or directory to delete","Details","Directories must be empty before using the os.remove() function to delete them.","If this function fails, it returns nil (for success) and an error message string (for msg).","Example","os.remove("testFile")","Delete the file named testFile.","Also see","os.rename()","os.remove()","19929.htm"); +Page[240]=new Array("This function renames an existing file or directory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","success, msg = os.rename("oldname", "newname")","success","A success indicator (true or nil)","msg","A message value (nil or an error message)","oldname","String representing the name of the file or directory to rename","newname","String represent the new name of the file or directory","Details","If this function fails, it returns nil (for success) and an error message string (for msg).","Example","os.rename("testFile", "exampleFile")","Changes the name of the existing file testFile to the name exampleFile.","Also see","os.remove()","os.rename()","19930.htm"); +Page[241]=new Array("This function generates a time value in UTC time.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","utcTime = os.time()","utcTime = os.time(timespec)","utcTime","Time value in UTC time","timespec","The date and time (year, month, day, hour, and minute)","Details","The timespec is a table using the fields listed in the table below.","year","The year (1970 or later)","month","The month (1 to 12)","day","The day (1 to 31)","hour","The hour (00 to 23)","min","The minute (00 to 59)","sec","The second (00 to 59)","If the time (hour, minute, and second) options are not used, they default to noon for that day. When called without a parameter (the first form), the function returns the current time.","Set the time zone before calling the os.time() function.","Example","systemTime = os.time({year = 2019,"," month = 3,"," day = 31,"," hour = 14,"," min = 25})","settime(systemTime)","Sets the date and time to Mar 31, 2019 at 2:25 pm.","Also see","settime()","settimezone()","os.time()","25959.htm"); +Page[242]=new Array("This function generates a response message.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","print(value1)","print(value1, value2)","print(value1, ..., valueN)","value1","The first argument to output","value2","The second argument to output","valueN","The last argument to output","...","One or more values separated with commas","Details","TSP-enabled instruments do not have inherent query commands. Like other scripting environments, the print() command and other related print() commands generate output. The print() command creates one response message.","The output from multiple arguments is separated with a tab character.","Numbers are printed using the format.asciiprecision attribute. If you want use Lua formatting, print the return value from the tostring() function.","Example 1","x = 10","print(x)","Example of an output response message:","10","Note that your output might be different if you set your ASCII precision setting to a different value.","Example 2","x = true","print(tostring(x))","Example of an output response message:","true","Also see","format.asciiprecision","print()","17645.htm"); +Page[243]=new Array("This function prints data from tables or reading buffer subtables.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","printbuffer(startIndex, endIndex, bufferVar)","printbuffer(startIndex, endIndex, bufferVar, bufferVar2)","printbuffer(startIndex, endIndex, bufferVar, ..., bufferVarN)","startIndex","Beginning index of the buffer to print; this must be more than one and less than endIndex","endIndex","Ending index of the buffer to print; this must be more than startIndex and less than the index of the last entry in the tables","bufferVar","First table or reading buffer subtable to print","bufferVar2","Second table or reading buffer subtable to print","bufferVarN","The last table or reading buffer subtable to print","...","One or more tables or reading buffer subtables separated with commas","Details","If startIndex ≤ 1, 1 is used as startIndex. If n < endIndex, n is used as endIndex.","When any given reading buffers are used in overlapped commands that have not yet completed (at least to the specified index), this function outputs data as it becomes available.","When there are outstanding overlapped commands to acquire data, n refers to the index that the last entry in the table has after all the measurements have completed.","If you pass a reading buffer instead of a reading buffer subtable, the default subtable for that reading buffer is used.","This command generates a single response message that contains all data. The response message is stored in the output queue.","The format.data attribute controls the format of the response message.","Example","format.data = format.ASCII","format.asciiprecision = 6","printbuffer(1, rb1.n, rb1)","This assumes that rb1 is a valid reading buffer in the runtime environment. The use of rb1.n","(bufferVar.n) indicates that the instrument should output all readings in the reading buffer. In this example, rb1.n equals 10.","Example of output data (rb1.readings):","4.07205e-05, 4.10966e-05, 4.06867e-05, 4.08865e-05, 4.08220e-05, 4.08988e-05, 4.08250e-05, 4.09741e-05, 4.07174e-05, 4.07881e-05","Also see","bufferVar.n","bufferVar.readings","format.asciiprecision","format.byteorder","format.data","printnumber()","printbuffer()","80596.htm"); +Page[244]=new Array("This function prints numbers using the configured format.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","printnumber(value1)","printnumber(value1, value2)","printnumber(value1, ..., valueN)","value1","First value to print in the configured format","value2","Second value to print in the configured format","valueN","Last value to print in the configured format","...","One or more values separated with commas","Details","There are multiple ways to use this function, depending on how many numbers are to be printed.","This function prints the given numbers using the data format specified by format.data and format.asciiprecision.","Example","format.asciiprecision = 10","x = 2.54","printnumber(x)","format.asciiprecision = 3","printnumber(x, 2.54321, 3.1)","Configure the ASCII precision to 10 and set x to 2.54.","Read the value of x based on these settings.","Change the ASCII precision to 3.","View how the change affects the output of x and some numbers.","Output:","2.540000000e+00","2.54e+00, 2.54e+00, 3.10e+00","Also see","format.asciiprecision","format.byteorder","format.data","print()","printbuffer()printbuffer()","printnumber()","15058.htm"); +Page[245]=new Array("This function resets commands to their default settings.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","reset()","reset(system)","system","What to reset:","true: If the node is the master, the entire system is reset (default)","false: Only the local group is reset","Details","The reset() command in its simplest form resets the entire TSP‑enabled system, including the controlling node and all subordinate nodes.","If you want to reset a specific instrument, use either the localnode.reset() or node[X].reset() command. Use the localnode.reset() command for the local instrument. Use the node[X].reset() command to reset an instrument on a subordinate node.","You can only reset the entire system using reset(true) if the node is the master. If the node is not the master node, executing this command generates an error.","Example","reset(true)","If the node is the master node, the entire system is reset; if the node is not the master node, an error is generated.","Also see","localnode.reset()","reset()","13933.htm"); +Page[246]=new Array("This KISavebuffer factory script function saves a specified reading buffer as either a CSV file or an XML file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","savebuffer(buffer, "formatType", "fileName")","buffer","The reading buffer to save","formatType","A string indicating which file type to use: csv or xml","fileName","The file name of the saved buffer","Details","Use this function to save the specified buffer to a USB flash drive.","This function will only save to a USB flash drive. ","You are not required to qualify the path to the USB flash drive, but you can add /usb1/ before the fileName (see Example 2).","Example 1","savebuffer(smua.nvbuffer1, "csv", "mybuffer.csv")","Save smua dedicated reading buffer 1 as a CSV file named mybuffer.csv.","Example 2","savebuffer(smua.nvbuffer1, "csv", "/usb1/mybuffer.csv")","Save smua dedicated reading buffer 1 to an installed USB flash drive as a CSV file named mybuffer.csv.","Also see","KISavebuffer factory script","smua.savebuffer()","savebuffer()","12959.htm"); +Page[247]=new Array("This is a reference to the anonymous script.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","No","See Details","See Details","Not applicable","Usage","scriptVar = script.anonymous","scriptVar","The name of the variable that references the script","Details","You can use the script.anonymous script like any other script. Also, you can save the anonymous script as a user script by giving it a name.","This script is replaced by loading a script with the loadscript or loadandrunscript commands when they are used without a name. ","Example 1","script.anonymous.list()","Displays the content of the anonymous script.","Example 2","print(script.anonymous.source)","Retrieves the source of the anonymous script.","Also see","Anonymous scripts","scriptVar.autorun","scriptVar.list()","scriptVar.name","scriptVar.run()","scriptVar.save()","scriptVar.source","script.anonymous","17040.htm"); +Page[248]=new Array("This function deletes a script from nonvolatile memory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","script.delete("scriptName")","scriptName","The string that represents the name of the script","Example","script.delete("test8")","Deletes a user script named "test8" from nonvolatile memory.","Also see","Delete user scripts from the instrument","scriptVar.save()","script.delete()","16853.htm"); +Page[249]=new Array("This function returns an iterator that can be used in a for loop to iterate over all the factory scripts.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","for name in script.factory.catalog() do body end","name","String representing the name of the script","body","Code that implements the body of the for loop to process the names in the catalog","Details","Accessing this catalog of scripts allows you to process the factory scripts. The entries will be enumerated in no particular order.","Each time the body of the function executes, name takes on the name of one of the factory scripts. The for loop repeats until all scripts have been iterated.","Example","for name in script.factory.catalog() do"," print(name)","end","Retrieve the catalog listing for factory scripts.","Also see","None","script.factory.catalog()","19931.htm"); +Page[250]=new Array("This function creates a script from a specified file.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","scriptVar = script.load("file")","scriptVar = script.load("file", "name")","scriptVar","The created script; this is nil if an error is encountered","file","The path and file name of the script file to load","name","The name of the script to be created","Details","The file path may be absolute or relative to the current working directory. The root folder of the USB flash drive has the absolute path "/usb1/". Both the forward slash (/) and backslash (\\) are supported as directory separators.","The file to be loaded must start with the loadscript or loadandrunscript keywords, contain the body of the script, and end with the endscript keyword.","Script naming:","If the name parameter is an empty string, or name is absent (or nil) and the script name cannot be extracted from the file, scriptVar is the only handle to the created script.","If name is given (and not nil), any script name embedded in the file is ignored.","If name conflicts with the name of an existing script in the script.user.scripts table, the existing script’s name attribute is set to an empty string before it is replaced in the script.user.scripts table by the new script.","If name is absent or nil, the command attempts to extract the name of the script from the file. Any conflict between the extracted name and that of an existing script in the scripts table generates an error. If the script name cannot be extracted, the created script's name attribute is initialized to the empty string and must be set to a valid nonempty string before saving the script to nonvolatile memory.","Example","myTest8 =
script.load("/usb1/filename.tsp", "myTest8")","Loads the script myTest8 from the USB flash drive.","Also see","script.new()","script.load()","15063.htm"); +Page[251]=new Array("This function creates a script.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","scriptVar = script.new("code")","scriptVar = script.new("code", "name")","scriptVar","The name of the variable that will reference the script","code","A string containing the body of the script","name","The name of the script","Details","The name parameter is the name that is added to the script.user.scripts table. If name is not given, an empty string is used, and the script is unnamed. If the name already exists in script.user.scripts, the existing script's name attribute is set to an empty string before it is replaced by the new script.","Note that name is the value that is used for the instrument front panel display. If this value is not defined, the script is not available from the front panel. ","You must save the new script into nonvolatile memory to keep it when the instrument is turned off.","Example 1","myTest8 = script.new("," "display.clear() display.settext('Hello from myTest8')", "myTest8")","myTest8()","Creates a new script referenced by the variable myTest8 with the name "myTest8".","Runs the script. The instrument displays "Hello from myTest8".","Example 2","autoexec = script.new("," "display.clear() display.settext('Hello from autoexec')", 'autoexec')","Creates a new autoexec script that clears the display when the instrument is turned on and displays "Hello from autoexec".","Also see","Create a script using the script.new() command","Global variables and the script.user.scripts table","Named scripts","scriptVar.save()","script.newautorun()","script.new()","15064.htm"); +Page[252]=new Array("This function creates a script and enables autorun.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","scriptVar = script.newautorun("code")","scriptVar = script.newautorun("code", "name")","scriptVar","The name of the variable that will reference the script","code","A string that contains the body of the script","name","The name of the script","Details","The name parameter is the name that is added to the script.user.scripts table. If name is not given, an empty string is used, and the script is unnamed. If the name already exists in script.user.scripts, the existing script's name attribute is set to an empty string before it is replaced by the new script.","Note that name is the value that is used for the instrument front panel display. If this value is not defined, the script is not available from the front panel. ","You must save the new script into nonvolatile memory to keep it when the instrument is turned off.","The script is run automatically immediately after it is created.","This command is the same as the script.new() function except that the script is automatically run.","Example","NewAuto = script.newautorun("print('Hello from new auto run command')", 'NewAuto')","print(NewAuto.autorun)","print(NewAuto.name)","Creates a new script called NewAuto that automatically has the autorun attribute set to yes after it is created. The name is set to "NewAuto".","Output:","Hello from new auto run command","yes","NewAuto","Also see","Create a script using the script.new() command","Global variables and the script.user.scripts table","Named scripts","script.new()","scriptVar.autorun","scriptVar.save()","script.newautorun()","18832.htm"); +Page[253]=new Array("This function restores a script that was removed from the runtime environment.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","script.restore(name)","name","The name of the script to be restored","Details","This command copies the script from nonvolatile memory into the runtime environment. It also creates a global variable with the same name as the name of the script.","Example","script.restore("test9")","Restores a script named test9 from nonvolatile memory.","Also see","script.delete()","script.restore()","16851.htm"); +Page[254]=new Array("This function runs the anonymous script.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","script.run()","run()","Details","Each time the script.run() command is given, the anonymous script is executed. This script can be run using this command many times without having to re-send it. ","Example","run()","Runs the anonymous script.","Also see","script.anonymous","script.run()","18833.htm"); +Page[255]=new Array("This function returns an iterator that can be used in a for loop to iterate over all the scripts stored in nonvolatile memory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","for name in script.user.catalog() do body end","name","String representing the name of the script","body","Code that implements the body of the for loop to process the names in the catalog","Details","This function accesses the catalog of scripts stored in nonvolatile memory, which allows you to process all scripts in nonvolatile memory. The entries are enumerated in no particular order.","Each time the body of the function executes, name takes on the name of one of the scripts stored in nonvolatile memory. The for loop repeats until all scripts have been iterated.","Example","for name in script.user.catalog() do"," print(name)","end","Retrieve the catalog listing for user scripts.","Also see","None","script.user.catalog()","16862.htm"); +Page[256]=new Array("This attribute controls the autorun state of a script.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","No","Not applicable","See Details","See Details","Usage","scriptVar.autorun = "state"","state = scriptVar.autorun","scriptVar","The name of the variable that references the script","state","String that indicates whether or not the script runs automatically when powered on:","yes: Script runs automatically","no: Script does not run automatically","Details","Autorun scripts run automatically when the instrument is turned on. You can set any number of scripts to autorun.","The run order for autorun scripts is arbitrary, so make sure the run order is not important.","The default value for scriptVar.autorun depends on how the script was loaded. The default is no if the script was loaded with loadscript or script.new(). It is yes for scripts loaded with loadandrunscript or script.newautorun().","@Make sure to save the script in nonvolatile memory after setting the autorun attribute so that the instrument keeps the setting.","Example","test5.autorun = "yes"","test5.save()","Assume a script named test5 is in the runtime environment.","The next time the instrument is turned on, test5 script automatically loads and runs.","Also see","None","scriptVar.autorun","16852.htm"); +Page[257]=new Array("This function generates a script listing.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","scriptVar.list()","scriptVar","The name of the variable that references the script","Details","This function generates output in the form of a sequence of response messages (one message for each line of the script). It also generates output of the script control messages (loadscript or loadandrunscript and endscript).","Example","test7 = script.new("display.clear() display.settext('Hello from my test')", "test7")","test7()","test7.save()","test7.list()","The above example code creates a script named test7 that displays text on the front panel and lists the script with the following output:","loadscript test7","display.clear() display.settext("Hello from my test")","endscript","Also see","Load a script by sending commands over the remote interface","Retrieve source code one line at a time","scriptVar.list()","17785.htm"); +Page[258]=new Array("This attribute contains the name of a script in the runtime environment.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","No","Not applicable","Not applicable","Not applicable","Usage","scriptVar.name = "scriptName"","scriptName = scriptVar.name","scriptVar","Name of the variable that references the script","scriptName","A string that represents the name of the script","Details","When setting the script name, this attribute renames the script that the variable scriptVar references.","This attribute must be either a valid Lua identifier or the empty string. Changing the name of a script changes the index that is used to access the script in the script.user.scripts table. Setting the attribute to an empty string removes the script from the table completely, and the script becomes an unnamed script.","As long as there are variables referencing an unnamed script, the script can be accessed through those variables. When all variables that reference an unnamed script are removed, the script is removed from the runtime environment.","If the new name is the same as a name that is already used for another script, the name of the other script is set to an empty string, and that script becomes unnamed. ","@Changing the name of a script does not change the name of any variables that reference that script. The variables still reference the script, but the names of the script and variables may not match.","Example","test7 = script.new("display.clear() display.settext('Hello from my test')", "")","test7()","print(test7.name)","test7.name = "test7"","print(test7.name)
","test7.save()","This example calls the script.new() function to create a script with no name, runs the script, names the script "test7", and then saves the script in nonvolatile memory.","Also see","Rename a script","script.new()","scriptVar.save()","scriptVar.name","2589.htm"); +Page[259]=new Array("This function runs a script.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","scriptVar.run()","scriptVar()","scriptVar","The name of the variable that references the script","Details","The scriptVar.run() function runs the script referenced by scriptVar. You can also run the script by using scriptVar().","To run a factory script, use script.factory.scripts.scriptName(), replacing scriptName with the name of the factory script.","Example","test8.run()","Runs the script referenced by the variable test8.","Also see","None","scriptVar.run()","16856.htm"); +Page[260]=new Array("This function saves the script to nonvolatile memory or to a USB flash drive.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","scriptVar.save()","scriptVar.save("filename")","scriptVar","The name of variable that references the script","filename","A string that contains the file name to use when saving the script to a USB flash drive","Details","The scriptVar.save() function saves a script to nonvolatile memory or a USB flash drive. The root folder of the USB flash drive has the absolute path /usb1/.","If no filename is specified (the file name parameter is an empty string), the script is saved to internal nonvolatile memory. Only a script with filename defined can be saved to internal nonvolatile memory. If a filename is given, the script is saved to the USB flash drive.","You can add the file extension, but it is not required. The only allowed extension is .tsp (see Example 2).","Example 1","test8.save()","Saves the script referenced by the variable test8 to nonvolatile memory.","Example 2","test8.save("/usb1/myScript.tsp")","Saves the script referenced by the variable test8 to a file named myScript.tsp on your USB flash drive.","Also see","Save a user script","scriptVar.save()","16863.htm"); +Page[261]=new Array("This attribute contains the source code of a script.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)
(see Details)","No","Not applicable","Not saved","Not applicable","Usage","code = scriptVar.source","scriptVar.source = nil","scriptVar","The name of the variable that references the script that contains the source code","code","A string that contains the body of the script","Details","The loadscript or loadandrunscript and endscript keywords are not included in the source code. ","The body of the script is a single string with lines separated by the new line character.","The instrument automatically stores the source for all scripts that are loaded on the instrument. To free up memory or to obfuscate the code, assign nil to the source attribute of the script. Although this attribute is writable, it can only be set to the nil value.","Example","test7 = script.new("display.clear() display.settext('Hello from my test')", "")","print(test7.source)","This example creates a script called test7 that displays a message on the front panel and retrieves the source code.","Output:","display.clear() display.settext('Hello from my test')","Also see","scriptVar.list()","scriptVar.source","16867.htm"); +Page[262]=new Array("This attribute configures the baud rate for the RS-232 port.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","9600","Usage","baud = serial.baud","serial.baud = baud","baud","The baud rate (300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, or 115200)","Details","A new baud rate setting takes effect when the command to change it is processed.","@Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set the baud rate from one of the other command interfaces or from the front panel.","The reset function has no effect on data bits.","Example","serial.baud = 1200","Sets the baud rate to 1200.","Also see","RS-232 interface operation","serial.databits","serial.flowcontrol","serial.parity","serial.baud","15068.htm"); +Page[263]=new Array("This attribute configures character width (data bits) for the RS-232 port.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","8","Usage","bits = serial.databits","serial.databits = bits","bits","An integer representing the character width (7 or 8)","Details","A new data width setting takes effect when the command to change it is processed.","@Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set the character width from one of the other command interfaces or from the front panel.","The reset function has no effect on data bits.","Example","serial.databits = 8","Sets data width to 8.","Also see","RS-232 interface operation","serial.baud","serial.flowcontrol","serial.parity","serial.databits","15069.htm"); +Page[264]=new Array("This attribute configures flow control for the RS-232 port.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory",""none" (serial.FLOW_NONE)","Usage","flow = serial.flowcontrol","serial.flowcontrol = flow","flow","A string or value that represents flow control configuration; set to:",""none" or serial.FLOW_NONE (selects no flow control)",""hardware" or serial.FLOW_HARDWARE (selects hardware flow control)","Details","A new flow control setting takes effect when the command to change it is processed.","@Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set the flow control from one of the other command interfaces or from the front panel.","The reset function has no effect on flow control.","Example","serial.flowcontrol = serial.FLOW_NONE","Sets flow control to none.","Also see","serial.baud","serial.databits","serial.parity","serial.flowcontrol","15070.htm"); +Page[265]=new Array("This attribute configures parity for the RS-232 port.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory",""none" (serial.PARITY_NONE)","Usage","parity = serial.parity","serial.parity = parity","parity","Set parity to one of the following values:","Select no parity ("none" or serial.PARITY_NONE)","Select even parity ("even" or serial.PARITY_EVEN)","Select odd parity ("odd" or serial.PARITY_ODD)","Details","A new parity setting takes effect when the command to change it is processed.","@Allow ample time for the command to be processed before attempting to communicate with the instrument again. If possible, set parity from one of the other command interfaces or from the front panel.","The reset function has no effect on parity.","Example","serial.parity = serial.PARITY_NONE","Sets parity to none.","Also see","RS-232 interface operation","serial.baud","serial.databits","serial.flowcontrol","serial.parity","15071.htm"); +Page[266]=new Array("This function reads available characters (data) from the serial port.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","data = serial.read(maxchars)","data","A string that consists of all data read from the serial port","maxchars","An integer that specifies the maximum number of characters to read","Details","This function reads available characters from the serial port. It does not wait for new characters to arrive. As long as maxchars is less than 200 characters, all characters that are received by the serial port (before the serial.read() command is executed) are returned. If too many characters are received between calls to this function, the RS-232 buffers will overflow and some characters may be lost.","Call this function as many times as necessary to receive the required number of characters. For optimal performance, use a small delay between repeated calls to this function.","The data returned is the raw data stream read from the port. No characters, such as control characters or terminator characters, are interpreted.","If you attempt to use this function when the serial port is enabled as a command interface, a settings conflict error is generated.","Example","data = serial.read(200)","print(data)","Read data from the serial port.","Output:","John Doe","The above output indicates that the string "John Doe" was read from the serial port.","Also see","serial.write()","serial.read()","15072.htm"); +Page[267]=new Array("This function writes data to the serial port.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","serial.write("data")","data","A string representing the data to write","Details","This function writes the specified string to the serial port, where it can be read by connected equipment (for example, a component handler). ","No terminator characters are added to the data, and data is written exactly as specified by the data parameter.","Example","serial.write("1 2 3 4")","Write data string "1 2 3 4" to the serial port.","Also see","serial.read()","serial.write()","15073.htm"); +Page[268]=new Array("This function sets the real-time clock (sets present time of the system).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","settime(time)","time","The time in seconds since January 1, 1970 UTC","Details","This function sets the date and time of the instrument based on the time parameter (specified in UTC time). UTC time is specified as the number of seconds since Jan 1, 1970, UTC. You can use UTC time from a local time specification, or you can use UTC time from another source (for example, your computer).","Example","systemTime = os.time({year = 2020,"," month = 3,"," day = 31,"," hour = 14,"," min = 25})","settime(systemTime)","Sets the date and time to Mar 31, 2020 at 2:25 pm.","Also see","gettimezone()","os.time()","settimezone()","settime()","13943.htm"); +Page[269]=new Array("This function sets the local time zone.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","settimezone(offset)","settimezone("offset", "dstOffset", "dstStart", "dstEnd")","offset","String representing offset from UTC","dstOffset","String representing the daylight savings offset from UTC","dstStart","String representing when daylight savings time starts","dstEnd","String representing when daylight savings time ends","Details","You only need to set the time zone if you use the os.time() and os.date() functions. ","If only one parameter is given, the same time offset is used throughout the year. If four parameters are given, time is adjusted twice during the year for daylight savings time.","offset and dstOffset are strings of the form "[+|-]hh[:mm[:ss]]" that indicate how much time must be added to the local time to get UTC time:","hh is a number between 0 and 23 that represents hours","mm is a number between 0 and 59 that represents minutes","ss is a number between 0 and 59 that represents seconds","The minute, second, +, and - fields are optional.","For example, to set the UTC-5 time zone, you specify the string "5", because UTC-5 is 5 hours behind UTC and you must add 5 hours to the local time to determine UTC time. To specify the time zone UTC4, you specify "-4", because UTC4 is 4 hours ahead of UTC and 4 hours must be subtracted from the local time to determine UTC.","dstStart and dstEnd are strings of the form "MM.w.dw/hh[:mm[:ss]]" that indicate when daylight savings time begins and ends respectively:","MM is a number between 1 and 12 that represents the month","w is a number between 1 and 5 that represents the week in the month","dw is a number between 0 and 6 that represents the day of the week (where 0 is Sunday)","The rest of the fields represent the time of day that the change takes effect:","hh represents hours","mm represents minutes","ss represents seconds","The minutes and seconds fields are optional.","The week of the month and day of the week fields are not specific dates.","Example","settimezone("8", "1", "3.3.0/02", "11.2.0/02")

","settimezone(offset)","Sets offset to equal +8 hours, +1 hour for DST, starts on Mar 14 at 2:00 am, ends on Nov 7 at 2:00 am.","Sets local time zone to offset.","Also see","gettimezone()","os.time()","settime()","settimezone()","15021.htm"); +Page[270]=new Array("This attribute specifies which saved setup to recall when the instrument is turned on.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","0","Usage","id = setup.poweron","setup.poweron = id","id","An integer that specifies the setup to recall when the instrument power is turned on (0 to 5)","Details","When id = 0, the instrument uses the factory default setup when it is turned on. When id is set to 1 to 5, it uses the setup saved with setup.save().","Only setups stored in nonvolatile memory are available (you cannot recall a script from a USB flash drive with this command).","To save a script that is used when the instrument is powered on, you can create a configuration script and name it autoexec.","Example","setup.poweron = 0","Set the instrument to use the factory default setup when power is turned on.","Also see","setup.save() ","Start-up (power-on) configuration","setup.poweron","15081.htm"); +Page[271]=new Array("This function recalls settings from a saved setup.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","setup.recall(id)","id","An integer or string that specifies the location of the setup to recall:","Factory default setup: 0","User-saved setup in nonvolatile memory: 1 to 5","User-saved setup on a USB flash drive: "/path/filename"","Details","When the id parameter is an integer (n), it is interpreted as the setup number to restore from the instrument's nonvolatile memory. When n = 0, the instrument recalls the factory default setup; when n = 1 to 5, the instrument recalls a user-saved setup.","When the id parameter is a string, it is interpreted as the path and file name of the setup to restore from a file on a USB flash drive. The path may be absolute or relative to the current working directory.","Before a setup is recalled, an instrument reset is performed.","Example 1","setup.recall(1)","Recall the user-saved setup at location 1.","Example 2","setup.recall("/usb1/KEITHLEY_30730.set")","Recall a user-saved setup stored in a file named KEITHLEY_30730 on a USB flash drive.","Also see","Saved setups","setup.save()","setup.recall()","66566.htm"); +Page[272]=new Array("This function saves the present setup as a user-saved setup.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","setup.save(id)","id","An integer or string specifying where to save the user setup:","Save in nonvolatile memory (1 to 5)","Save as user-saved setup on a USB flash drive ("/path/filename")","Details","When the id parameter is an integer (n), it is interpreted as the setup number to save to the instrument's nonvolatile memory.","@When you save to a specified integer (1 to 5) in nonvolatile memory, the previous setup at that same location is overwritten.","When the id parameter is a string, it is interpreted as the path and file name of the location to save the present setup on a USB flash drive. The path may be absolute or relative to the current working directory.","Example","setup.save(5)","Saves the present setup to the internal memory of the instrument at location 5.","Also see","Saved setups","setup.recall()","setup.save()","15083.htm"); +Page[273]=new Array("This function terminates all overlapped operations on the source‑measure unit (SMU).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.abort()","Details","The smua.abort() function does not turn the output off or change any settings.","If this function is used to abort a sweep, when it is executed, the SMU exits its trigger model immediately and returns to the idle state of the trigger model.","Example","smua.abort()","Terminates all overlapped operations.","Also see","smua.measure.overlappedY()","smua.trigger.initiate()","smua.abort()","15088.htm"); +Page[274]=new Array("This function returns the statistics for a specified reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","statistics = smua.buffer.getstats(bufferVar)","statistics","The statistical data about the data in the reading buffer","bufferVar","The reading buffer to process","Details","This function returns a table with statistical data about the data that is placed in the buffer.","The SMU automatically updates reading buffer statistics as data is added to the reading buffer. When the reading buffer is configured to wrap around and overwrite older data with new data, the buffer statistics include the data that was overwritten.","The table returned from this function is a snapshot. Although the SMU continues to update the statistics, the table returned is not updated. To get fresh statistics, call this function again.","The statistics parameter has the attributes described in the following table.","Attribute","When returned","Description","n","Always","The number of data points on which the statistics are based","mean","When n > 0","The average of all readings added to the buffer","stddev","When n > 1","The standard deviation of all readings (samples) added to the buffer","min","When n > 0","A table containing data about the minimum reading value added to the buffer","max","When n > 0","A table containing data about the maximum reading value added to the buffer","If n equals zero (0), all other attributes are nil. If n equals 1, the stddev attribute is nil because the standard deviation of a sample size of 1 is undefined.","The min and max entries each have the attributes defined in the following table.","Attribute","Description","measurefunction","String indicating the function that was measured for the reading (current, voltage, ohms or watts)","measurerange","The full-scale range value for the measurement range used when the measurement was made","reading","The reading value","sourcefunction","String indicating the source function at the time of the measurement (current or voltage)","sourceoutputstate","String indicating the state of the source (off or on)","sourcerange","Full-scale range value for the source range used when the measurement was made","sourcevalue","If bufferVar.collectsourcevalues is enabled, the sourced value in effect at the time of the reading","status","Status value for the reading; the status value is a floating-point number that encodes the status value into a floating-point value","timestamp","If bufferVar.collecttimestamps is enabled, the timestamp, in seconds, between when the reading was acquired and when the first reading in the buffer was acquired; adding this value to the base timestamp will give the actual time the measurement was acquired","Example","reset()","smua.nvbuffer1.clear()","smua.measure.count = 10","smua.measure.v(smua.nvbuffer1)","stats = smua.buffer.getstats(smua.nvbuffer1)","print("n= "..stats.n)","print("mean= "..stats.mean)","print("stddev= "..stats.stddev)","print("min= "..stats.min.reading)","print("max= "..stats.max.reading)","Make measurements and store them in nvbuffer1. Print the statistics for the data.","Example output:","n= 10","mean= -2.3851394871599e-05","stddev= 4.406545187484e-07","min= -2.4557113647461e-05","max= -2.322196996829e-05","Also see","smua.buffer.recalculatestats()","smua.buffer.getstats()","18554.htm"); +Page[275]=new Array("This function recalculates the statistics of the specified reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.buffer.recalculatestats(bufferVar)","bufferVar","The reading buffer to process","Details","This function causes the SMU to regenerate the reading buffer statistics about the specified reading buffer. Because the SMU automatically updates reading buffer statistics when data is added to the reading buffer, this function is generally not needed. When the reading buffer is configured to wrap around and overwrite older data with new data, the buffer statistics will include the data that was overwritten. Use this function to recalculate the statistics that include only the data that is presently stored in the buffer.","Example","smua.buffer.recalculatestats(smua.nvbuffer1)","Recalculates the statistics of buffer smua.nvbuffer1.","Also see","bufferVar.fillmode","smua.buffer.getstats()","smua.buffer.recalculatestats()","18556.htm"); +Page[276]=new Array("This attribute stores the date of the last calibration adjustment.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU cal. restore","SMU nonvolatile memory","Initially set to factory
calibration date","Usage","adjustDate = smua.cal.adjustdate","smua.cal.adjustdate = adjustDate","adjustDate","Date of the last adjustment","Details","This attribute stores the adjustment date associated with the active calibration set. The adjustment date can be read at any time but can only be assigned a new value when calibration has been enabled with the smua.cal.unlock() function.","You cannot change the adjustment date without first making a change to the calibration constants.","Once you change any calibration constants, you must set the adjustment date before you can save the calibration data to the nonvolatile memory of the SMU.","This attribute is stored with the active calibration set. If a different calibration set is restored, this attribute reflects the date stored with that set.","smua.cal.adjustdate must be set to the date the adjustment was done using the UTC time and date. The date is stored as the number of seconds since UTC, 12:00 am Jan 1, 1970.","Due to the internal storage format, smua.cal.adjustdate is only accurate to within a few minutes of the value set.","Example","smua.cal.adjustdate = os.time()","Sets the adjustment date to the current time set on the instrument.","Also see","Adjustment","os.time()","smua.cal.date","smua.cal.due","smua.cal.lock()","smua.cal.restore()","smua.cal.save()","smua.cal.state","smua.cal.unlock()","smua.cal.adjustdate","15093.htm"); +Page[277]=new Array("This attribute stores the calibration date of the active calibration set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU calibration restore","SMU nonvolatile memory","Initially set to factory calibration date","Usage","calDate = smua.cal.date","smua.cal.date = calDate","calDate","The calibration date of the active calibration set","Details","This attribute stores the calibration date that is associated with the active calibration set. The calibration date can be read at any time but can only be assigned a new value when calibration has been enabled with the smua.cal.unlock() function. It is typically set to the date when the instrument was calibrated.","This attribute is stored with the active calibration set. If a different calibration set is restored, this attribute will reflect the date stored with that set.","smua.cal.date must be set to the date the calibration was done using the UTC time and date. The date is stored as the number of seconds since UTC 12:00 am Jan 1, 1970.","Due to the internal storage format, smua.cal.date is accurate to within a few minutes of the value set.","Example","smua.cal.date = os.time()","Sets calibration date to the present time set on the instrument.","Also see","Adjustment","os.time()","smua.cal.adjustdate","smua.cal.due","smua.cal.lock()","smua.cal.restore()","smua.cal.save()","smua.cal.state","smua.cal.unlock()","smua.cal.date","15094.htm"); +Page[278]=new Array("This attribute stores the calibration due date for the next calibration.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU cal. restore","SMU nonvolatile memory","0","Usage","calDue = smua.cal.due","smua.cal.due = calDue","calDue","Due date of next calibration (0 indicates that no date is set)","Details","This attribute stores the calibration due date associated with the active calibration set. The calibration due date can be read at any time but can only be assigned a new value when calibration has been enabled with the smua.cal.unlock() function. It is typically set to the date when the next calibration should be performed.","This attribute is stored with the active calibration set. If a different calibration set is restored, this attribute reflects the due date stored with that set.","smua.cal.due must be set to the date the next calibration is required using the UTC time and date. The date is stored as the number of seconds since UTC 12:00 am Jan 1, 1970.","Due to the internal storage format, smua.cal.due is only accurate to within a few minutes of the value set.","Example","smua.cal.due = os.time() + 365 * 24 * 60 * 60","Sets the calibration due date equal to one year from the present time set on the instrument.","Also see","Adjustment","os.time()","smua.cal.adjustdate","smua.cal.date","smua.cal.lock()","smua.cal.restore()","smua.cal.state","smua.cal.unlock()","smua.cal.due","15095.htm"); +Page[279]=new Array("This function disables the commands that change calibration settings.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.cal.lock()","Details","Before you can lock calibration, the calibration constants must be written to nonvolatile memory or a previous calibration set must be restored. Error code 5012, "Cal data not saved - save or restore before lock," results if this function is called when the calibration state is smua.CALSTATE_CALIBRATING. ","Example","smua.cal.lock()","Disables calibration functions.","Also see","Adjustment","smua.cal.restore()","smua.cal.save()","smua.cal.state","smua.cal.unlock()","smua.cal.lock()","15089.htm"); +Page[280]=new Array("This attribute stores the password required to enable calibration.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (W)","Yes","Not applicable","SMU nonvolatile memory",""KI0026XX"","Usage","smua.cal.password = "newPassword"","newPassword","A string that contains the new password","Details","A new password can only be assigned when calibration has been unlocked.","The calibration password is write-only and cannot be read.","Example","smua.cal.password = "LetMeIn"","Assigns a new calibration password.","Also see","Adjustment","smua.cal.unlock()","smua.cal.password","15096.htm"); +Page[281]=new Array("This attribute controls which calibration constants are used for all subsequent measurements.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
SMU calibration lock
Recall setup","Not saved","0 (smua.CAL_AUTO)","Usage","calPolarity = smua.cal.polarity","smua.cal.polarity = calPolarity","calPolarity","The polarity to use for measurements. Set to one of the following values:","0 or smua.CAL_AUTO: Automatic polarity detection","1 or smua.CAL_POSITIVE: Measure with positive polarity calibration constants","2 or smua.CAL_NEGATIVE: Measure with negative polarity calibration constants","Details","This attribute controls which polarity calibration constants are used to make all subsequent measurements.","This attribute does not affect the smua.measure.calibrateY() and smua.pulser.measure.calibrateY() commands. The polarity for the measure calibrate commands is dictated by their range parameters. The measure calibration commands require the measurements provided to have been made using the polarity being calibrated.","When making measurements for points far away from zero, the desired polarity constants are inherently used. However, when making measurements near zero, it is possible that the instrument could use the calibration constants from the wrong polarity. Setting smua.cal.polarity to positive or negative forces measurements to be made using the calibration constants for a given polarity, rather than basing the choice on the raw measurement data.","This attribute can only be set to positive or negative when calibration is unlocked. This attribute is automatically set to smua.CAL_AUTO when calibration is locked.","Example","smua.cal.polarity = smua.CAL_POSITIVE","Selects positive calibration constants for all subsequent measurements.","Also see","Adjustment","reset()","smua.cal.lock()","smua.cal.unlock()","smua.measure.calibrateY()","smua.pulser.measure.calibrateY()","smua.reset()","smua.cal.polarity","93060.htm"); +Page[282]=new Array("This function loads a stored set of calibration constants.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.cal.restore()","smua.cal.restore(calset)","calset","The calibration set to be loaded; set calset to one of the following values:","0 or smua.CALSET_NOMINAL: A set of calibration constants that are uncalibrated, but set to nominal values to allow rudimentary functioning of the instrument","1 or smua.CALSET_FACTORY: The calibration constants when the instrument left the factory","2 or smua.CALSET_DEFAULT: The normal calibration set","3 or smua.CALSET_PREVIOUS: The calibration set that was used before the last default set was overwritten","Details","This function overwrites the present set of calibration constants with constants read from nonvolatile memory.","This function is disabled until a successful call to smua.cal.unlock() is made.","If calset is not specified, smua.CALSET_DEFAULT is used.","Example","smua.cal.restore()","Restores factory calibration constants.","Also see","Adjustment","smua.cal.lock()","smua.cal.unlock()","smua.cal.restore()","15090.htm"); +Page[283]=new Array("This function stores the active calibration constants to nonvolatile memory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.cal.save()","Details","This function stores the active set of calibration constants to nonvolatile memory. The previous calibration constants (from the default calibration set) are copied to the previous calibration set (smua.CALSET_PREVIOUS) before overwriting the default calibration set.","This function is disabled until a successful call to smua.cal.unlock() is made.","If any of the calibration constants have been changed, this function is disabled unless the calibration date, the calibration due date, and the calibration adjust date have been assigned new values.","Example","smua.cal.save()","Stores calibration constants in nonvolatile memory.","Also see","Adjustment","smua.cal.adjustdate","smua.cal.date","smua.cal.due","smua.cal.lock()","smua.cal.restore()","smua.cal.unlock()","smua.cal.save()","15091.htm"); +Page[284]=new Array("This attribute returns the present calibration state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not saved","Not applicable","Usage","calState = smua.cal.state","calState","The present calibration state; when reading this attribute, calState has one of the following values:","0 or smua.CALSTATE_LOCKED: Calibration is locked","1 or smua.CALSTATE_CALIBRATING: The calibration constants or dates have been changed but not yet saved to nonvolatile memory","2 or smua.CALSTATE_UNLOCKED: Calibration is unlocked but none of the calibration constants or dates have changed since the last save/restore","Details","This read-only attribute indicates the calibration state of the instrument: Locked, calibrating, or unlocked.","Example","calstate = smua.cal.state","print(calstate)","Reads calibration state.","Output:","0.000000e+00","The above output indicates that calibration is locked.","Also see","Adjustment","smua.cal.lock()","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.cal.state","15098.htm"); +Page[285]=new Array("This function enables the commands that change calibration settings.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.cal.unlock(password)","password","Calibration password","Details","This function enables the calibration functions to change the calibration settings.","The password when the instrument is shipped from the factory is "KI0026XX".","Example","smua.cal.unlock("KI0026XX")","Unlocks calibration.","Also see","Adjustment","smua.cal.lock()","smua.cal.password","smua.cal.state","smua.cal.unlock()","15092.htm"); +Page[286]=new Array("This function adjusts the high/sense high contact check measurement. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.contact.calibratehi(cp1Measured, cp1Reference, cp2Measured, cp2Reference)","cp1Measured","The value measured by this SMU for point 1","cp1Reference","The reference measurement for point 1 as measured externally","cp2Measured","The value measured by this SMU for point 2","cp2Reference","The reference measurement for point 2 as measured externally","Details","Contact check measurement calibration does not require range information.","Typically, points one and two will be near 0 Ω and 50 Ω, respectively.","All four measurements (cp1Measured, cp1Reference, cp2Measured, and cp2Reference) must be made with the calibration set that is active. If not, corruption of the calibration constants may result.","The new calibration constants are activated immediately but are not written to nonvolatile memory. Use smua.cal.save() to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.","This function is disabled until a successful call to smua.cal.unlock() is made.","Example","-- Short SENSE LO and LO terminals.","-- Short SENSE HI and HI terminals.","-- Allow readings to settle, then get measurements.","r0_hi, r0_lo = smua.contact.r()","-- Connect 50 OHM resistor between SENSE LO and LO.","-- Connect 50 OHM resistor between SENSE HI and HI.","-- Allow readings to settle, then get measurements.","r50_hi, r50_lo = smua.contact.r()","smua.contact.calibratelo(r0_lo, Z_actual_lo, r50_lo, 50_ohm_actual_lo)","smua.contact.calibratehi(r0_hi, Z_actual_hi, r50_hi, 50_ohm_actual_hi)","The instrument performs a contact check.","Install and measure two resistors.","The user sends the contact check LO calibration command.","The user sends the contact check HI calibration command.","Also see","Adjustment","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.contact.calibratelo()","smua.contact.calibratehi()","15099.htm"); +Page[287]=new Array("This function adjusts the low/sense low contact check measurement. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.contact.calibratelo(cp1Measured, cp1Reference, cp2Measured, cp2Reference)","cp1Measured","The value measured by this SMU for point 1","cp1Reference","The reference measurement for point 1 as measured externally","cp2Measured","The value measured by this SMU for point 2","cp2Reference","The reference measurement for point 2 as measured externally","Details","Contact check measurement adjustment does not require range information.","Typically, points one and two are near 0 Ω and 50 Ω, respectively.","All four measurements (cp1Measured, cp1Reference, cp2Measured, and cp2Reference) must be made with the active calibration set. If not, corruption of the calibration constants may result.","The new calibration constants are activated immediately but are not written to nonvolatile memory. Use smua.cal.save() to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.","This function is disabled until a successful call to smua.cal.unlock() is made.","Example","-- Short SENSE LO and LO terminals.","-- Short SENSE HI and HI terminals.","-- Allow readings to settle, then get measurements.","r0_hi, r0_lo = smua.contact.r()","-- Connect 50 OHM resistor between SENSE LO and LO.","-- Connect 50 OHM resistor between SENSE HI and HI.","-- Allow readings to settle, then get measurements.","r50_hi, r50_lo = smua.contact.r()","smua.contact.calibratelo(r0_lo, Z_actual_lo, r50_lo, 50_ohm_actual_lo)","smua.contact.calibratehi(r0_hi, Z_actual_hi, r50_hi, 50_ohm_actual_hi)","The instrument performs a contact check.","Install and measure two resistors.","The user sends the contact check LO calibration command.","The user sends the contact check HI calibration command.","Also see","Adjustment","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.contact.calibratehi()","smua.contact.calibratelo()","15100.htm"); +Page[288]=new Array("This function determines if contact resistance is lower than the threshold.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.contact.check()","Details","@Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser. See Example 1: Ten-point pulse sweep for a code example.","This function returns true if the contact resistance is below the threshold; this function returns false if it is above the threshold. The threshold value is set by the smua.contact.threshold attribute.","When the output is on and any of the following:","SMU is a current source with current range set to less than 1 mA (error code 5065, "I range too low for contact check")","SMU is a voltage source with current limit set to less than 1 mA (error code 5050, "I limit too low for contact check")","When the output is off and any of the following:","The output off mode is High-Z (error code 5048, "Contact check not valid with HIGH-Z OUTPUT off")","The output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCVOLTS and the off current limit set to less than 1 mA (error code 5066, "source.offlimiti too low for contact check")","The output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCAMPS and the source range is less than 1 mA (error code 5065, "I range too low for contact check")","If you attempt to perform a contact check measurement when any of the above conditions exist, an error is generated.","Example","if not smua.contact.check() then"," -- take action","end","Takes action if contact check fails.","Also see","Contact check connections","Contact check measurements","smua.contact.speed","smua.contact.threshold","smua.source.offfunc","smua.contact.check()","92517.htm"); +Page[289]=new Array("This function measures aggregate contact resistance. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","rhi, rlo = smua.contact.r()","rhi","The measured aggregate contact resistance on the HI/sense HI side","rlo","The measured aggregate contact resistance on the LO/sense LO side","Details","If you attempt to perform a contact resistance measurement when any of the following conditions exist, an error is generated.","When the output is on and SMU is a current source with current range set to less than 1 mA","When the output is on and SMU is a voltage source with current limit set to less than 1 mA","When the output is off and the output off mode is High-Z","When the output is off and the output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCVOLTS and the off current limit set to less than 1 mA","When the output is off and the output off mode is Normal with the smua.source.offfunc attribute set to smua.OUTPUT_DCAMPS and the source range is less than 1 mA","When the pulser is enabled (smua.pulser.enable attribute is set to smua.ENABLE)","@Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser.","Example","if not smua.contact.check() then"," smua.contact.speed = smua.CONTACT_SLOW"," rhi, rlo = smua.contact.r()"," print(rhi, rlo)"," exit()","end","Check contacts against threshold.","Set speed to slow.","Get resistance readings.","Output contact resistances.","Terminate execution.","Also see","Contact check connections","Contact check measurements","smua.contact.check()","smua.contact.speed","smua.contact.r()","92712.htm"); +Page[290]=new Array("This attribute stores the speed setting for contact check measurements.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Not saved","0 (smua.CONTACT_FAST)","Usage","speedSetting = smua.contact.speed","smua.contact.speed = speedSetting","speedSetting","The speed setting. Set to one of the following:","0 or smua.CONTACT_FAST","1 or smua.CONTACT_MEDIUM","2 or smua.CONTACT_SLOW","Details","This setting controls the aperture of measurements made for contact check. It does not affect the smua.measure.nplc aperture setting.","The speed setting can have a dramatic effect on the accuracy of the measurement (see the specifications).","@Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser.","Example","smua.contact.speed = smua.CONTACT_SLOW","Configure contact check for higher accuracy.","Also see","Contact check connections","Contact check measurements","reset()","smua.contact.check()","smua.contact.r()","smua.reset()","smua.contact.speed","92519.htm"); +Page[291]=new Array("This attribute stores the resistance threshold for the smua.contact.check() function.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Not saved","50 (50 Ω)","Usage","rValue = smua.contact.threshold","smua.contact.threshold = rValue","rValue","The resistance above which contact check should fail (measured in ohms)","Details","The threshold should be set to less than 1 kΩ.","@Contact check is not available when the pulser is enabled. If you need to use the contact check function in a pulser application, you can disable the pulser, run the contact check measurements, then enable the pulser.","Example","smua.contact.threshold = 5","Set the contact check threshold to 5 Ω.","Also see","Contact check connections","Contact check measurements","reset()","smua.contact.check()","smua.reset()","smua.contact.threshold","92520.htm"); +Page[292]=new Array("This attribute enables or disables use of the interlock signal.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","smua.DISABLE","Usage","interlockState = smua.interlock.enable","smua.interlock.enable = interlockState","interlockState","Enable or disable use of the interlock signal:","Turn the output off if the interlock signal is not asserted: smua.ENABLE","Ignore the interlock signal: smua.DISABLE","Details","The setting of this attribute must match the jumper setting on the 2601B-P-INT Interlock and Cable Connector Box.","Example","smua.interlock.enable = smua.ENABLE","Enable the interlock.","Also see","Using the interlock","smua.interlock.enable","92713.htm"); +Page[293]=new Array("This function creates a reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","bufferVar = smua.makebuffer(bufferSize)","bufferVar","The created reading buffer","bufferSize","Maximum number of readings that can be stored","Details","Reading buffers can be created and allocated dynamically using this function. Use bufferSize to designate the number of readings the buffer can store.","Dynamically allocated reading buffers can be used interchangeably with the smua.nvbufferY buffers.","A reading buffer can be deleted by setting all references to the reading buffer equal to nil, then running the garbage collector (see the collectgarbage() function in Standard libraries).","Example","mybuffer2 = smua.makebuffer(200)","Creates a 200 element reading buffer (mybuffer2).","Also see","collectgarbage() in Base library functions","Remote reading buffer programming","savebuffer()","smua.nvbufferY","smua.makebuffer()","15105.htm"); +Page[294]=new Array("This attribute stores the measurement autorange setting.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","1 (smua.AUTORANGE_ON)","Usage","autoRange = smua.measure.autorangeY","smua.measure.autorangeY = autoRange","autoRange","The state of the measurement autorange setting; set to one of the following values:","0 or smua.AUTORANGE_OFF: Disabled","1 or smua.AUTORANGE_ON: Enabled","2 or smua.AUTORANGE_FOLLOW_LIMIT: Measure range automatically set to the limit range","Y","SMU measure function (v = voltage, i = current)","Details","This attribute indicates the measurement autorange state. Its value is smua.AUTORANGE_OFF when the SMU measure circuit is on a fixed range and smua.AUTORANGE_ON when it is in autorange mode.","Setting this attribute to smua.AUTORANGE_OFF puts the SMU on a fixed range. The fixed range is the present SMU measure range.","Setting this attribute to smua.AUTORANGE_ON puts the SMU measure circuit in autorange mode. It remains on its present measure range until the next measurement is requested.","If source high capacitance mode is enabled, current autorange is set to smua.AUTORANGE_FOLLOW_LIMIT and cannot be changed.","Example","smua.measure.autorangev = smua.AUTORANGE_ON","Enables voltage measurement autoranging.","Also see","Autoranging","Range","reset()","setup.recall()","smua.measure.rangeY","smua.reset()","smua.measure.autorangeY","15107.htm"); +Page[295]=new Array("This attribute enables or disables automatic updates to the internal reference measurements (autozero) of the instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","2 (smua.AUTOZERO_AUTO)","Usage","azMode = smua.measure.autozero","smua.measure.autozero = azMode","azMode","Indicates status of autozero; set to one of the following values:","0 or smua.AUTOZERO_OFF: Autozero disabled","1 or smua.AUTOZERO_ONCE: Performs autozero once, then disables autozero","2 or smua.AUTOZERO_AUTO: Automatic checking of reference and zero measurements; an autozero is performed when needed","Details","The analog-to-digital converter (ADC) uses a ratiometric A/D conversion technique. To ensure the accuracy of readings, the instrument must periodically obtain new measurements of its internal ground and voltage reference. The time interval between updates to these reference measurements is determined by the integration aperture being used for measurements. The 2601B-PULSE uses separate reference and zero measurements for each aperture.","By default, the instrument automatically checks these reference measurements whenever a signal measurement is made. If the reference measurements have expired when a signal measurement is made, the instrument will automatically take two more A/D conversions, one for the reference and one for the zero, before returning the result. Thus, occasionally, a measurement takes longer than normal.","This additional time can cause problems in sweeps and other test sequences in which measurement timing is critical. To avoid the time that is needed for the reference measurements in these situations, you can use the smua.measure.autozero attribute to disable the automatic reference measurements.","Disabling automatic reference measurements may allow the instrument to gradually drift out of specification. To minimize the drift, a reference and zero measurement should be made immediately before any critical test sequences. You can use the smua.AUTOZERO_ONCE setting to force a refresh of the reference and zero measurements that are used for the present aperture setting.","The 2601B-PULSE stores the reference measurements for the last ten NPLC settings that were used in a reference cache. If an NPLC setting is selected and an entry for it is not in the cache, the oldest (least recently used) entry is discarded to make room for the new entry.","When the pulser is enabled, two high-speed digitizing sampling ADCs are used to measure voltage and current. These ADCs do not use a ratiometric conversion technique, so the autozero settings are ignored when the pulser is enabled.","Example","smua.measure.autozero = smua.AUTOZERO_ONCE","Performs autozero once.","Also see","Autozero","reset()","smua.measure.nplc","setup.recall()","smua.reset()","smua.measure.autozero","93207.htm"); +Page[296]=new Array("This function generates and activates new measurement calibration constants.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.measure.calibrateY(range, cp1Measured, cp1Reference, cp2Measured, cp2Reference)","Y","SMU measurement function (v = voltage, i = current)","range","The measurement range to adjust","cp1Measured","The value measured by this SMU for point 1","cp1Reference","The reference measurement for point 1 as measured externally","cp2Measured ","The value measured by this SMU for point 2","cp2Reference ","The reference measurement for point 2 as measured externally","Details","This function generates and activates new calibration constants for the given range.","The positive and negative polarities of the instrument must be adjusted separately. Use a positive value for range to adjust the positive polarity and a negative value for range to adjust the negative polarity.","Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.","All four measurements (cp1Measured, cp1Reference, cp2Measured, and cp2Reference) must be made with the calibration set that is active. Corruption of the calibration constants may result if this is ignored.","The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.","This function is only available when calibration is unlocked using smua.cal.unlock().","Example","smua.measure.calibratev(1, 1e-4, 1e-5, 0.92, 0.903)","Adjust SMU channel A voltage measurement using the following values:","1 V calibration range","1e-4 for +zero measurement reading","1e-5 for +zero DMM measurement reading","0.92 for +FS measurement reading","0.903 for the +FS DMM measurement reading","Also see","Adjustment","smua.cal.lock()","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.source.calibrateY()","smua.measure.calibrateY()","15109.htm"); +Page[297]=new Array("This attribute sets the number of measurements made when a measurement is requested.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","1","Usage","count = smua.measure.count","smua.measure.count = count","count","Number of measurements","Details","This attribute controls the number of measurements made any time a measurement is requested. When using a reading buffer with a measure command, this attribute also controls the number of readings to be stored.","If the count is set to a value greater than 1, any measurement delay set by smua.measure.delay only occurs before the first measurement, while the smua.measure.interval controls the interval between successive measurements.","When the pulser is enabled and measurements are not overlapped, this attribute must be less than 3500.","Example","smua.measure.count = 10","Sets the measure count to 10.","Also see","reset()","setup.recall()","smua.measure.delay","smua.measure.interval","smua.measure.overlappedY()","smua.measure.Y()","smua.reset()","smua.measure.count","92991.htm"); +Page[298]=new Array("This attribute controls the measurement delay.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","0 (smua.DELAY_OFF)","Usage","mDelay = smua.measure.delay","smua.measure.delay = mDelay","mDelay","Set to the measurement delay value in seconds (for example, to specify an additional 10 ms measurement delay, set the value to 0.010)","You can also set it to one of the following values:","0 or smua.DELAY_OFF: No delay","-1 or smua.DELAY_AUTO: Automatic delay value","Details","This attribute allows for additional delay (settling time) before making a measurement. If you define the value instead of using the automatic delay value, the delay you set is used regardless of the range.","The smua.DELAY_AUTO setting causes a current range-dependent delay to be inserted when a current measurement is requested. This happens when a current measurement command is executed, when the measure action is being performed in a sweep, or after changing ranges during an autoranged measurement.","If smua.measure.count is greater than 1, the measurement delay is only inserted before the first measurement.","Example","smua.measure.delay = 0.010","Sets a 10 ms measurement delay.","Also see","Measure auto delay","reset()","smua.measure.count","smua.measure.delayfactor","smua.source.delay","smua.reset()","smua.measure.delay","92241.htm"); +Page[299]=new Array("This attribute stores a multiplier to the delays that are used when smua.measure.delay is set to smua.DELAY_AUTO.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Not saved","1","Usage","delayFactor = smua.measure.delayfactor","smua.measure.delayfactor = delayFactor","delayFactor","The delay factor multiplier","Details","The delay factor is only applied when smua.measure.delay = smua.DELAY_AUTO.","This attribute can be set to a value less than 1 (for example, 0.5) to decrease the automatic delay.","This attribute can be set to a value greater than 1 (for example, 1.5 or 2.0) to increase the automatic delay.","Setting this attribute to zero disables delays when smua.measure.delay = smua.DELAY_AUTO.","Example","smua.measure.delayfactor = 2.0","Doubles the measure delay.","Also see","Measure auto delay","reset()","smua.measure.delay","smua.reset()","smua.measure.delayfactor","15112.htm"); +Page[300]=new Array("This command sets the number of measured readings that are required to yield one filtered measurement.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","1","Usage","filterCount = smua.measure.filter.count","smua.measure.filter.count = filterCount","filterCount","The number of readings required for each filtered measurement (1 to 100)","Details","This attribute sets the size of the stack used for filtered measurements.","Example","smua.measure.filter.count = 10","smua.measure.filter.type = smua.FILTER_MOVING_AVG","smua.measure.filter.enable = smua.FILTER_ON","Sets the filter count to 10.","Sets the filter type to moving average.","Enables the filter.","Also see","Filters","reset()","setup.recall()","smua.measure.filter.enable","smua.measure.filter.type","smua.reset()","smua.measure.filter.count","15113.htm"); +Page[301]=new Array("This command enables or disables filtered measurements.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","0 (smua.FILTER_OFF)","Usage","filterState = smua.measure.filter.enable","smua.measure.filter.enable = filterState","filterState","The filter status; set to one of the following values:","0 or smua.FILTER_OFF: Disables the filter","1 or smua.FILTER_ON: Enables the filter","Details","This command enables or disables the filter.","Example","smua.measure.filter.count = 10","smua.measure.filter.type = smua.FILTER_MOVING_AVG","smua.measure.filter.enable = smua.FILTER_ON","Sets the filter count to 10.","Sets the filter type to moving average.","Enables the filter.","Also see","Filters","reset()","setup.recall()","smua.measure.filter.count","smua.measure.filter.type","smua.reset()","smua.measure.filter.enable","15114.htm"); +Page[302]=new Array("This command sets the type of filter used for measurements when the measurement filter is enabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","1 (smua.FILTER_REPEAT_AVG)","Usage","filterType = smua.measure.filter.type","smua.measure.filter.type = filterType","filterType","The filter type to use when filtering is enabled. Set to one of the following values:","0 or smua.FILTER_MOVING_AVG: Selects the moving filter","1 or smua.FILTER_REPEAT_AVG: Selects the repeat filter","2 or smua.FILTER_MEDIAN: Selects the median filter","Details","The 2601B-PULSE provides a moving average, repeating average, and median filter type.","For the repeating filter, the stack (filter count) is filled, and the conversions are averaged to yield a reading. The stack is then cleared, and the process starts over. ","The moving average filter uses a first-in, first-out stack. When the stack (filter count) becomes full, the measurement conversions are averaged, yielding a reading. For each subsequent conversion placed into the stack, the oldest conversion is discarded. The stack is re-averaged, yielding a new reading.","The median filter uses a first-in, first-out stack. When the stack (filter count) becomes full, the reading nearest to the middle is returned. For each subsequent conversion placed into the stack, the oldest reading is discarded. The stack is then re-sorted, yielding a new reading. If the filter count is an even number, the reading returned is the average of the two middle readings.","@If the pulser is enabled, the repeating filter is the only available filter.","Example","smua.measure.filter.count = 10","smua.measure.filter.type = smua.FILTER_MOVING_AVG","smua.measure.filter.enable = smua.FILTER_ON","Sets the filter count to 10.","Sets the filter type to moving average.","Enables the filter.","Also see","Filters","reset()","setup.recall()","smua.measure.filter.count","smua.measure.filter.enable","smua.reset()","smua.measure.filter.type","92979.htm"); +Page[303]=new Array("This attribute contains a delay multiplier that is only used during range changes when the high-capacitance mode is active.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","10","Usage","delayFactor = smua.measure.highcrangedelayfactor","smua.measure.highcrangedelayfactor = delayFactor","delayFactor","The delay factor; set to a value between 1 and 99","Details","This delay multiplier is only active when the high-capacitance mode is active.","Example","smua.measure.highcrangedelayfactor = 5","Increases the delay used during range changes by a factor of 5.","Also see","High-capacitance mode","reset()","setup.recall()","smua.reset()","smua.source.highc","smua.measure.highcrangedelayfactor","15116.htm"); +Page[304]=new Array("This attribute sets the interval between multiple measurements.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","0 (0 s)","Usage","interval = smua.measure.interval","smua.measure.interval = interval","interval","The interval value (in seconds); set to a value between 0 and 1","Details","This attribute sets the time interval between measurements when smua.measure.count is set to a value greater than 1.","The SMU attempts to start each measurement when scheduled. When the pulser is disabled, if the SMU cannot keep up with the interval setting, measurements are made as quickly as possible. When the pulser is enabled and the trigger model is not configured for asynchronous measurements, if the SMU cannot keep up with the interval setting, it aborts the sweep and turns the output off.","If filtered measurements are being made, the time interval is from the start of the first measurement for the filtered reading to the first measurement for a subsequent filtered reading. Extra measurements made to satisfy a filtered reading are not paced by this interval.","When the measure count is greater than 1 and the pulser is enabled, this must be less than 65 ms.","Example","smua.measure.interval = 0.5","Sets the measure interval to 0.5 s.","Also see","reset()","setup.recall()","smua.measure.count","smua.reset()","smua.measure.interval","92990.htm"); +Page[305]=new Array("This attribute sets the lowest measurement range that is used when the instrument is autoranging.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","Current: 100e-9 (100 nA)
Voltage: 100e-3 (100 mV)","Usage","lowRange = smua.measure.lowrangeY","smua.measure.lowrangeY = lowRange","lowRange","The lowest voltage or current measurement range used during autoranging","Y","SMU measure function (v = voltage, i = current)","Details","This attribute is used with autoranging to put a lower bound on the range used. Since lower ranges generally require greater settling times, setting a lowest range limit might make measurements require less settling time.","If the instrument is set to autorange and it is on a range lower than the one specified, the range is changed to the lowRange range value.","Example","smua.measure.lowrangev = 1","Sets voltage low range to 1 V.","Also see","Range","reset()","setup.recall()","smua.measure.autorangeY","smua.reset()","smua.measure.lowrangeY","92333.htm"); +Page[306]=new Array("This command sets the integration aperture for measurements when the pulser is disabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","1.0","Usage","nplc = smua.measure.nplc","smua.measure.nplc = nplc","nplc","The integration aperture; set from 0.001 to 25","Details","This attribute controls the integration aperture for the analog‑to‑digital converter (ADC) that is used when the pulser is disabled.","The integration aperture is based on the number of power line cycles (NPLC), where 1 PLC for 60 Hz is 16.67 ms (1/60) and 1 PLC for 50 Hz is 20 ms (1/50).","Example","smua.measure.nplc = 0.5","Sets the integration time to 0.5.","Also see","Speed","reset()","setup.recall()","smua.pulser.measure.aperture","smua.reset()","smua.measure.nplc","93175.htm"); +Page[307]=new Array("This function starts an asynchronous (background) measurement.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","smua.measure.overlappedY(rbuffer)","smua.measure.overlappediv(ibuffer, vbuffer)","Y","SMU measurement type (v = voltage, i = current, r = resistance, p = power)","rbuffer","A reading buffer object where the readings are stored","ibuffer","A reading buffer object where current readings are stored","vbuffer","A reading buffer object where voltage readings are stored","Details","This function starts a measurement and returns immediately. The measurements, as they are performed, are stored in a reading buffer (along with any other information that is being acquired). If the instrument is configured to return multiple readings where one is requested, the readings are available as they are made. Measurements are in the following units of measure: v = volts, i = amperes, r = ohms, p = watts.","The second form of this function, smua.measure.overlappediv(), stores current readings in ibuffer and voltage readings in vbuffer.","This function is an overlapped command. Script execution continues while the measurements are made in the background. Attempts to access result values that have not yet been generated cause the script to block and wait for the data to become available. The waitcomplete() function can also be used to wait for the measurements to complete before continuing.","If a given reading buffer contains any data, it is cleared before making any measurements, unless the reading buffer has been configured to append data.","Example","smua.measure.overlappedv(smua.nvbuffer1)","Starts background voltage measurements.","Also see","Reading buffers","smua.measure.Y()","smua.nvbufferY","waitcomplete()","smua.measure.overlappedY()","15120.htm"); +Page[308]=new Array("This attribute contains the positive full‑scale value of the measurement range for voltage or current.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","Voltage: 100e-3 (100 mV)
Current: 100e-3 (100 mA)","Usage","rangeValue = smua.measure.rangeY","smua.measure.rangeY = rangeValue","rangeValue","Set to the maximum expected voltage or current to be measured","Y","SMU measurement function (v = voltage, i = current)","Details","Reading this attribute returns the positive full-scale value of the measurement range that the SMU is currently using. Assigning a value to this attribute sets the SMU on a fixed range large enough to measure the assigned value. The instrument will select the best range for measuring a value of rangeValue.","This attribute is primarily intended to eliminate the time that is required by the automatic range selection performed by a measuring instrument. Because selecting a fixed range prevents autoranging, an overrange condition can occur. For example, measuring 10.0 V on the 6 V range causes an overrange. The value 9.91000E+37 is returned when this occurs.","If the source function is the same as the measurement function (for example, sourcing voltage and measuring voltage), the measurement range is locked to be the same as the source range. However, the setting for the measure range is retained. If the source function is changed (for example, from sourcing voltage to sourcing current), the retained measurement range is used.","For example, assume the source function is voltage. The source range is 1 V and you set the measure range for 6 V. Since the source range is 1 V, the SMU performs voltage measurements on the 1 V range. If you now change the source function to current, voltage measurements are made on the 6 V range.","Explicitly setting a measure range will disable measure autoranging for that function. Autoranging is controlled separately for each source and measurement function: source voltage, source current, measure voltage and measure current. Autoranging is enabled for all four by default.","Changing the range while the output is off does not update the hardware settings, but querying returns the range setting that will be used once the output is turned on. Setting a range while the output is on takes effect immediately.","With measure autoranging enabled, the range is changed only when a measurement is taken. Querying the range after a measurement returns the range selected for that measurement.","Example","smua.measure.rangev = 0.5","Selects the 1 V measurement range.","Also see","Range","reset()","setup.recall()","smua.measure.autorangeY","smua.pulser.rangeY","smua.reset()","smua.source.rangeY","smua.measure.rangeY","92317.htm"); +Page[309]=new Array("This attribute turns relative measurements on or off. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Not saved","0 (smua.REL_OFF)","Usage","relEnable = smua.measure.rel.enableY","smua.measure.rel.enableY = relEnable","relEnable","Relative measurement control. Set relEnable to one of the following values:","0 or smua.REL_OFF: Disables relative measurements","1 or smua.REL_ON: Enables relative measurements","Y","SMU measurement function (v = voltage, i = current, r = resistance, p = power)","Details","This attribute enables or disables relative measurements. When relative measurements are enabled, all subsequent measured readings are offset by the relative offset value specified by smua.measure.rel.levelY. Each returned measured relative reading is the result of the following calculation:","Relative reading = Actual measured reading - Relative offset value","Example","smua.measure.rel.enablev = smua.REL_ON","Enables relative voltage measurements.","Also see","Relative offset","reset()","setup.recall()","smua.measure.rel.levelY","smua.reset()","smua.measure.rel.enableY","15123.htm"); +Page[310]=new Array("This attribute sets the offset value for relative measurements.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Not saved","0","Usage","relValue = smua.measure.rel.levelY","smua.measure.rel.levelY = relValue","relValue","Relative measurement offset value","Y","SMU measurement function (v = voltage, i = current, r = resistance, p = power)","Details","This attribute specifies the offset value used for relative measurements. When relative measurements are enabled (see smua.measure.rel.enableY), all subsequent measured readings will be offset by the value of this attribute. Each returned measured relative reading is the result of the following calculation: ","Relative reading = Actual measured reading - Relative offset value","Example","smua.measure.rel.levelv = smua.measure.v()","Performs a voltage measurement and then uses it as the relative offset value.","Also see","Relative offset","reset()","smua.measure.rel.enableY","smua.reset()","smua.measure.rel.levelY","15124.htm"); +Page[311]=new Array("This function makes one or more measurements.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","reading = smua.measure.Y()","reading = smua.measure.Y(readingBuffer)","iReading, vReading = smua.measure.iv()","iReading, vReading = smua.measure.iv(iReadingBuffer)","iReading, vReading = smua.measure.iv(iReadingBuffer, vReadingBuffer)","reading","Returned value of the last (or only) reading of the measurement process","Y","SMU measurement function (v = voltage, i = current, r = resistance, p = power)","readingBuffer","A reading buffer object where all readings are stored","iReading","The last reading of the current measurement process","vReading","The last reading of the voltage measurement process","iReadingBuffer","A reading buffer object where current readings are stored","vReadingBuffer","A reading buffer object where voltage readings are stored","Details","If you use this function without specifying a reading buffer, it makes one measurement and returns that measurement as reading. To use the additional information that is acquired while making a measurement or to return multiple readings, specify a reading buffer. If the instrument is configured to return multiple readings for a measurement and readingBuffer is specified, all readings are available in readingBuffer, but only the last measurement is returned as reading.","Measurements are in the following units of measure:","v = volts","i = amperes","r = ohms","p = watts","The smua.measure.iv() function returns the last actual current measurement and voltage measurement as iReading and vReading, respectively. Additionally, it can store current and voltage readings if buffers are provided (iReadingBuffer and vReadingBuffer ).","The smua.measure.count attribute determines how many measurements are performed. When using a reading buffer, it also determines the number of readings to store in the buffer. If a reading buffer is not specified, the SMU ignores the smua.measure.count attribute and only makes one measurement.","The readingBuffer is cleared before making any measurements unless the buffer is configured to append data.","Example","smua.measure.count = 10","smua.measure.v(smua.nvbuffer1)","Makes 10 voltage measurements using SMU channel A and stores them in a buffer.","Also see","Reading buffers","smua.measure.count","smua.measure.overlappedY()","smua.nvbufferY","smua.measure.Y()","15122.htm"); +Page[312]=new Array("This function makes one or two measurements and then steps the source.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","reading = smua.measureYandstep(sourceValue)","iReading, vReading = smua.measureivandstep(sourceValue)","reading","The measured reading before stepping the source","Y","SMU measurement function (v = voltage, i = current, r = resistance, p = power)","sourceValue","Source value to be set after the measurement is made","iReading","The current reading before stepping the source","vReading","The voltage reading before stepping the source","Details","The smua.measureYandstep() function makes a measurement and then sets the source to sourceValue. The smua.measureivandstep() function makes two measurements simultaneously, one for current (i) and one for voltage (v), and then sets the source to sourceValue.","Measurements are in the following units of measure: v = volts, i = amperes, r = ohms, p = watts.","The specified source value should be appropriate for the selected source function. For example, if the source voltage function is selected, then sourceValue is expected to be a new voltage level.","Both source and measure autorange must be disabled before using this function. This function cannot be used if source high capacitance mode is enabled (high capacitance mode requires autoranging to be enabled).","This function is provided for very fast execution of source-measure loops. The measurement is made before the source is stepped. Before using this function, and before any loop this function may be used in, set the source value to its initial level.","@This function is not available when the pulser is enabled.","Example","local ivalues = {}","smua.source.rangev = 1","smua.source.levelv = 0","smua.measure.rangei = 0.01","smua.source.output = smua.OUTPUT_ON","for index = 1, 10 do"," ivalues[index] = smua.measureiandstep(index / 10)","end","ivalues[11] = smua.measure.i()","This use of the measure and step function measures current, starting at a source value of 0 V. After each current measurement, the source is stepped 100 mV for the next current measurement. The final source level is 1 V, where current is measured again.","Also see","smua.measure.autorangeY","smua.measure.Y()","smua.source.autorangeY","smua.trigger.source.limitY","smua.trigger.source.linearY()","smua.trigger.source.listY()","smua.trigger.source.logY()","Sweep Operation","smua.measureYandstep()","93173.htm"); +Page[313]=new Array("This attribute contains a dedicated reading buffer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","See Details","Not applicable","Usage","bufferVar = smua.nvbufferY","bufferVar","The dedicated reading buffer","Y","Nonvolatile buffer (1 or 2)","Details","The SMU contains two dedicated reading buffers: smua.nvbuffer1 and smua.nvbuffer2.","All routines that return measurements can also store them in either reading buffer. Overlapped measurements are always stored in a reading buffer. Synchronous measurements return either a single-point measurement or can be stored in a reading buffer if passed to the measurement command.","The dedicated reading buffers can be saved to internal nonvolatile memory (to retain data between power cycles) using the smua.savebuffer() function.","Example","smua.measure.overlappedv(smua.nvbuffer1)","Store voltage readings into dedicated reading buffer 1.","Also see","Configuring and running sweeps","Reading buffers","savebuffer()","smua.makebuffer()","smua.measure.overlappedY()","smua.savebuffer()","smua.trigger.measure.action","smua.trigger.measure.set()","smua.trigger.measure.stimulus","smua.trigger.measure.Y()","smua.nvbufferY","92706.htm"); +Page[314]=new Array("This attribute enables or disables the 2601B-PULSE pulser.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","smua.DISABLE","Usage","enable = smua.pulser.enable","smua.pulser.enable = enable","enable","Enable or disable the pulser; set to:","smua.DISABLE: Conventional pulsing and full source‑measure unit (SMU) functionality","smua.ENABLE: Allow fast-edge pulsing using the trigger model","Details","When the pulser is enabled, there are the following differences in source-measure unit (SMU) functionality:","You can only source current (not voltage).","If the output exceeds a maximum pulse width, maximum duty cycle, or the specified protection level during a sweep, the 2601B-PULSE output is shorted, but the sweep continues with no source output until it is finished.","Some SMU settings are ignored; see Settings ignored when the pulser is enabled for details.","The smua.trigger.source.pulsewidth and smua.pulser.measure.delay attributes provide more precise timing than you can achieve using the smua.trigger.endpulse.stimulus and smua.trigger.measure.stimulus attributes.","Some of the output‑off modes behave differently:","OUTPUT_NORMAL: The output circuit is shorted when this output-off mode is selected.","OUTPUT_ZERO: The output circuit is shorted and current cannot be measured when this output-off mode is selected.","You cannot use contact check.","You cannot make measurements when the output is off.","Example","smua.pulser.enable = smua.ENABLE","Enable the pulser.","Also see","Pulser operation","smua.pulser.measure.delay","smua.trigger.source.pulsewidth","smua.pulser.enable","91674.htm"); +Page[315]=new Array("This attribute specifies the pulse measurement aperture when the pulser is enabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","0.000001","Usage","aperture = smua.pulser.measure.aperture","smua.pulser.measure.aperture = aperture","aperture","The measurement aperture; set from 0.000001 s to 0.1 s","Details","When using this attribute with the trigger model or in a pulse-width limited region, the sum of the measure delay and the total measure time must be less than the pulse width. The total measure time depends on the measure count, the filter count, and the measure interval."," The settings for this attribute are ignored if the pulser is disabled.","Example","smua.pulser.measure.aperture = 10e-6","Set the measurement aperture to 10 µs.","Also see","smua.trigger.source.pulsewidth","smua.pulser.measure.aperture","91672.htm"); +Page[316]=new Array("This function generates and activates new measurement calibration constants for the pulser.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.pulser.measure.calibrateY(range, cp1Measured, cp1Reference, cp2Measured, cp2Reference)","range","The pulse measurement range to adjust","Y","The measurement function (v = voltage, i = current)","cp1Measured","The value measured by this SMU for point 1","cp1Reference","The reference measurement for point 1 as measured externally","cp2Measured","The value measured by this SMU for point 2","cp2Reference","The reference measurement for point 2 as measured externally","Details","This function generates and activates new calibration constants for the given range. ","The positive and negative polarities of the instrument must be adjusted separately. Use a positive value for range to adjust the positive polarity and a negative value for range to adjust the negative polarity.","Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.","The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.","This function is only available when calibration is unlocked using smua.cal.unlock().","Example","smua.pulser.measure.calibratei(1, 0.01, 0.011, 0.75, 0.76)","Adjusts the current measurement using the following values:","1 A measurement range","0.01 for the +zero measurement reading","0.011 for the +zero DMM measurement reading","0.75 for the + full‑scale measurement reading","0.76 for the + full‑scale DMM measurement reading","Also see","Calibration","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.pulser.source.calibratebiasi()","smua.pulser.source.calibratei()","smua.pulser.measure.calibrateY()","91895.htm"); +Page[317]=new Array("This attribute sets the measurement delay when the pulser is enabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","0","Usage","delay = smua.pulser.measure.delay","smua.pulser.measure.delay = delay","delay","The measurement delay value in seconds; set from 0 to 0.065","Details","Use this attribute with the trigger model when performing a pulse sweep.","Set the delay parameter to a nonzero value to specify when a measurement starts during a pulse. The measurement starts after the delay interval expires. This allows the 2601B-PULSE to locate measurements within a pulse with less jitter than those generated using the measure trigger stimulus in the trigger model.","The sum of the measure delay and the total measure time must be less than the pulse width configured with the smua.trigger.source.pulsewidth setting. The total measure time depends on the measure count, the filter count, and the measure interval.","You cannot use this attribute and a measurement stimulus in the trigger model at the same time.","@Using both the end-pulse stimulus and this attribute in a script may cause the pulse output to end before the specified duration of the pulse is completed, causing invalid measurements.","When this attribute is set to zero, measurements are only triggered by a measurement stimulus.","The settings for this attribute are ignored if the pulser is disabled.","Example","smua.pulser.measure.delay = 35e-6","smua.pulser.measure.aperture = 10e-6","Specify a 35 µs pulse measure delay and a 10 µs measurement aperture.","Also see","Triggering","smua.pulser.measure.aperture","smua.pulser.enable","smua.trigger.source.pulsewidth","smua.pulser.measure.delay","91673.htm"); +Page[318]=new Array("This attribute sets a voltage protection level used to monitor the sense terminals when the pulser is enabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","20 V","Usage","level = smua.pulser.protect.sensev","smua.pulser.protect.sensev = level","level","The voltage protection level when the pulser is enabled; the value must be between 5% and 200% of the voltage range set by the smua.pulser.rangeY attribute","Details","If the voltage on the sense terminals goes above the protection level, the 2601B-PULSE output is shorted for the remainder of the sweep and the output turns off at the end of the sweep.","The current pulse terminates within 3 µs after the remotely sensed voltage from the device under test (DUT) exceeds the specified level.","@Setting the protection level does not guarantee that the output will not go above the protection level. The 2601B-PULSE turns off the output as quickly as possible, but the voltage level can briefly exceed this level, potentially causing damage to the device under test (DUT).","The settings for this attribute are ignored if the pulser is disabled.","Example","smua.pulser.protect.sensev = 8","Set the voltage protection limit to 8 V.","Also see","smua.pulser.protect.sourcev","smua.pulser.protect.tripped","smua.pulser.rangeY","smua.pulser.protect.sensev","91675.htm"); +Page[319]=new Array("This attribute sets an absolute voltage protection level used to monitor the force terminals when the pulser is enabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","40 V","Usage","level = smua.pulser.protect.sourcev","smua.pulser.protect.sourcev = level","level","The absolute voltage protection level when the pulser is enabled; 2 V to 40 V","Details","If the voltage on the force terminals goes above the protection level, the 2601B-PULSE automatically turns off the output.","The absolute voltage protection level ignores normal transients during the pulse rise and fall time.","The current pulse terminates within 3 µs after the remotely sensed voltage from the device under test (DUT) exceeds the specified level.","@Setting the protection level does not guarantee that the output will not go above the protection level. The 2601B-PULSE turns off the output as quickly as possible, but the voltage level can briefly exceed this level, potentially causing damage to the device under test (DUT).","The settings for this attribute are ignored if the pulser is disabled.","Example","smua.pulser.protect.sourcev = 8","Set the voltage protection limit to 8 V.","Also see","smua.pulser.protect.sensev","smua.pulser.protect.tripped","smua.pulser.protect.sourcev","92539.htm"); +Page[320]=new Array("This attribute indicates if the protection circuit was tripped.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Instrument reset
SMU reset","None","Not applicable","Usage","tripped = smua.pulser.protect.tripped","tripped","The voltage protection status:","true: The protection circuit was tripped","false: The protection circuit was not tripped","Details","When the pulser is enabled, this attribute indicates if the protection circuit was tripped. When the protection circuit is tripped, the output is shorted and turned off.","The following events can trip the protection circuit:","A voltage greater than smua.pulser.protect.sensev was detected on the sense terminals.","A voltage greater than smua.pulser.protect.sourcev was detected on the force terminals.","The maximum pulse width was exceeded during trigger model operation.","The maximum duty cycle was exceeded during trigger model operation.","If the SMU cannot keep up with the pulse rate.","If the SMU cannot keep up with the measurement rate.","The status is reset to false when the pulser is disabled or when the output is turned on.","Example","print(smua.pulser.protect.tripped)","Determine if the protection circuit was tripped.","Also see","smua.pulser.protect.sensev","smua.pulser.protect.sourcev","smua.pulser.protect.tripped","91676.htm"); +Page[321]=new Array("This attribute sets the source and measure ranges when the pulser is enabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","Current: 10 A
Voltage: 10 V","Usage","range = smua.pulser.rangei","range = smua.pulser.rangev","smua.pulser.rangei = range","smua.pulser.rangev = range","range","The source and measure range","Details","When you set a value for the range, the 2601B-PULSE automatically sets the range as appropriate for the specified value.","This attribute setting affects the settings that are allowed for the smua.pulser.protect.sensev attribute, which must be between 5 percent and 200 percent of the voltage range.","The following table lists the pulser limits for the voltage and current functions.","Voltage range","Source","Measure","5 V","Not applicable","5.1 V","10 V","Not applicable","10.2 V","Current ranges","1 A","±1.01 A","±1.02 A","5 A","±5.05 A","±5.1 A","10 A","±10.1 A","±10.2 A","250 mA (DC bias)","±250 mA","Selected pulse measure range","The settings for this attribute are ignored if the pulser is disabled.","Example","smua.pulser.rangei = 1","Set the pulser current range to 1 A.","Also see","smua.pulser.protect.sensev","smua.pulser.rangeY","91677.htm"); +Page[322]=new Array("This function generates and activates new bias source calibration constants for the pulser.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.pulser.source.calibratebiasi(range, cp1Expected, cp1Reference, cp2Expected, cp2Reference)","range","The pulser bias current range to adjust","cp1Expected","The source value set for point 1","cp1Reference","The reference measurement for point 1 as measured externally","cp2Expected","The source value set for point 2","cp2Reference","The reference measurement for point 2 as measured externally","Details","The positive and negative polarities must be adjusted separately. To adjust the positive polarity, use the +250e-3 range; to adjust the negative polarity, use the -250e-3 range.","Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.","The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.","This function is only available when calibration is unlocked using smua.cal.unlock().","Example","smua.pulser.source.calibratebiasi(250e-3, 1e-10, 1e-5, 0.224, 0.225)","Adjusts the bias source calibration constant for the 250e-3 pulser range using 1e-10 as the source value and 1e-5 for the reference measurement for point 1 and 0.224 as the source value and 0.225 as the reference measurement for point 2.","Also see","Calibration","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.pulser.measure.calibrateY()","smua.pulser.source.calibratei()","smua.pulser.source.calibratebiasi()","91897.htm"); +Page[323]=new Array("This function generates and activates new source calibration constants for the pulser.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.pulser.source.calibratei(range, cp1Expected, cp1Reference, cp2Expected, cp2Reference)","range","The pulser current range to adjust","cp1Expected","The source value set for point 1","cp1Reference","The reference measurement for point 1 as measured externally","cp2Expected","The source value set for point 2","cp2Reference","The reference measurement for point 2 as measured externally","Details","This function generates and activates new calibration constants for the given range. ","Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.","The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.","This function is only available when calibration is unlocked using smua.cal.unlock().","Example","smua.pulser.source.calibratei(1, 1e-10, 1e-5, 0.9, 0.903)","Generates and activates new source calibration constants for the pulser 1 A range. For point 1, it uses 1e-10 as the source value and 1e-5 as the reference measurement. For point 2, it uses 0.9 for the source value and 0.903 for the reference measurement.","Also see","Calibration","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.pulser.measure.calibrateY()","smua.pulser.source.calibratebiasi()","smua.pulser.source.calibratei()","91898.htm"); +Page[324]=new Array("This function turns off the output and resets the commands that begin with smua. to their default settings.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.reset()","Details","This function turns off the output and returns the specified SMU to its default settings.","Example","smua.reset()","Turns off the output and resets SMU to its default settings.","Also see","reset()","smua.reset()","15136.htm"); +Page[325]=new Array("This function saves one source‑measure unit (SMU) dedicated reading buffer to nonvolatile memory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.savebuffer(smua.nvbufferY)","Y","SMU dedicated reading buffer (1 or 2)","Details","When the instrument is turned off and back on, the dedicated reading buffers are restored from nonvolatile memory to their last saved values.","Example","smua.savebuffer(smua.nvbuffer1)","Saves buffer 1 to internal memory.","Also see","Reading buffers","savebuffer()","smua.nvbufferY","smua.savebuffer()","15137.htm"); +Page[326]=new Array("This attribute contains the state of the sense mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","0 (smua.SENSE_LOCAL)","Usage","senseMode = smua.sense","smua.sense = senseMode","senseMode","The sense mode; set to one of the following:","0 or smua.SENSE_LOCAL: Selects local sense (2-wire)","1 or smua.SENSE_REMOTE: Selects remote sense (4-wire)","3 or smua.SENSE_CALA: Selects calibration sense mode","Details","You can do source-measure operations using either 2-wire local sense connections or 4-wire remote sense connections.","@When the pulser is enabled, the instrument always uses 4‑wire remote sensing. The setting of smua.sense is ignored.","You can change the sense mode between local and remote while the output is on.","The smua.SENSE_CALA mode is only used for calibration and may only be selected when calibration is enabled. The calibration sense mode cannot be selected while the output is on.","Example","smua.sense = smua.SENSE_REMOTE","Select 4-wire remote sensing.","Also see","2-wire local sensing connections","4-wire remote sensing connections","Sense mode selection","smua.sense","93042.htm"); +Page[327]=new Array("This attribute contains the state of the source autorange control (on/off). ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","1 (smua.AUTORANGE_ON)","Usage","sourceAutorange = smua.source.autorangeY","smua.source.autorangeY = sourceAutorange","sourceAutorange","The state of the source autorange control. Set to one of the following:","0 or smua.AUTORANGE_OFF: Disables source autorange","1 or smua.AUTORANGE_ON: Enables source autorange","Y","SMU source function (v = voltage, i = current)","Details","This attribute indicates the source autorange state. Its value is smua.AUTORANGE_OFF when the SMU source circuit is on a fixed range and smua.AUTORANGE_ON when it is in autorange mode.","Setting this attribute to smua.AUTORANGE_OFF puts the SMU on a fixed source range. The fixed range used is the present SMU source circuit range.","Setting this attribute to smua.AUTORANGE_ON puts the SMU source circuit into autorange mode. If the source output is on, the SMU immediately changes range to the range most appropriate for the value being sourced if that range is different than the present SMU range.","Autorange is disabled if the source level is edited from the front panel. Setting the source range also turns off autorange when set by using the smua.source.rangeY attribute.","Resetting the instrument selects the smua.AUTORANGE_ON.","Example","smua.source.autorangev = smua.AUTORANGE_ON","Enables volts source autorange.","Also see","smua.measure.autorangeY","smua.source.rangeY","smua.source.autorangeY","15139.htm"); +Page[328]=new Array("This function generates and activates new source calibration constants.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.source.calibrateY(range, cp1Expected, cp1Reference, cp2Expected, cp2Reference)","Y","SMU source function (v = voltage, i = current)","range","The measurement range to adjust","cp1Expected","The source value set for point 1","cp1Reference","The reference measurement for point 1 as measured externally","cp2Expected","The source value set for point 2","cp2Reference","The reference measurement for point 2 as measured externally","Details","This function generates and activates new calibration constants for the given range.","The positive and negative polarities of the source must be adjusted separately. Use a positive value for range to adjust the positive polarity and a negative value for range to adjust the negative polarity. Do not use 0.0 for a negative point; 0.0 is considered to be a positive number.","Typically, the two points that are used are near zero for point 1 and 90% of full scale for point 2. Full scale for point 2 should be avoided if the source of the SMU is substantially out of calibration.","The two reference measurements must be made with the source using the active calibration set. For example, source a value, measure it, and do not change the active calibration set before issuing this command.","The new calibration constants are activated immediately but they are not written to nonvolatile memory. Use the smua.cal.save() function to save the new constants to nonvolatile memory. The active calibration constants stay in effect until the instrument is power cycled or a calibration set is loaded from nonvolatile memory with the smua.cal.restore() function.","This function is only available when calibration is unlocked using smua.cal.unlock().","Example","smua.source.calibratev(1, 1e-10, 1e-5, 0.9, 0.903)","Generates and activates new source calibration constants for the 1 A range. For point 1, it uses 1e-10 as the source value and 1e-5 as the reference measurement. For point 2, it uses 0.9 for the source value and 0.903 for the reference measurement.","Also see","Calibration","smua.cal.restore()","smua.cal.save()","smua.cal.unlock()","smua.measure.calibrateY()","smua.source.calibrateY()","15143.htm"); +Page[329]=new Array("This attribute contains the state of source compliance. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not saved","Not applicable","Usage","compliance = smua.source.compliance","compliance","The state of source compliance:","true: Indicates that the limit function is in control of the source (source in compliance)","false: Indicates that the source function is in control of the output (source not in compliance)","Details","Reading this attribute updates the status model and the front panel with generated compliance information. See Current Limit (ILMT) in the status model diagram for the Measurement event registers. The Voltage Limit (VLMT) is not shown in the status model diagram for the Measurement event registers, but is similar to the Current Limit (ILMT).","Example","compliance = smua.source.compliance","print(compliance)","Reads the source compliance state.","Output:","true","This output indicates that a configured limit has been reached (voltage, current, or power limit).","Also see","smua.source.limitY","smua.source.compliance","15141.htm"); +Page[330]=new Array("This attribute contains the source delay.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.DELAY_OFF)","Usage","sDelay = smua.source.delay","smua.source.delay = sDelay","sDelay","Set to the source delay value (for example, to specify an additional 10 ms source delay, set the value to 0.010); you can also set it one of the following values:","0 or smua.DELAY_OFF: No delay","-1 or smua.DELAY_AUTO: Automatic delay value","Details","This attribute allows for additional delay (settling time) after an output step.","The smua.DELAY_AUTO setting causes a range-dependent delay to be inserted when the source is changed. Range-dependent delays are based on the output settling time values as defined in the 2601B-PULSE specifications.","Example","smua.source.delay = smua.DELAY_AUTO","Sets the delay to automatic (a range-dependent delay is inserted whenever the source is changed).","Also see","reset()","smua.measure.count","smua.measure.delay","smua.reset()","smua.source.delay","15142.htm"); +Page[331]=new Array("This attribute contains the source function, which can be voltage or current.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","1 (smua.OUTPUT_DCVOLTS)","Usage","sFunction = smua.source.func","smua.source.func = sFunction","sFunction","The source function; set to one of the following values:","0 or smua.OUTPUT_DCAMPS: Selects the current source function","1 or smua.OUTPUT_DCVOLTS: Selects the voltage source function","Details","Reading this attribute indicates the output function of the source. Setting this attribute configures the SMU as either a voltage source or a current source.","Example","smua.source.func = smua.OUTPUT_DCAMPS","Sets the source function to be a current source.","Also see","smua.source.levelY","smua.source.output","smua.source.func","15144.htm"); +Page[332]=new Array("This attribute enables or disables high-capacitance mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","0 (smua.DISABLE)","Usage","highC = smua.source.highc","smua.source.highc = highC","highC ","The state of the high-capacitance mode; set to one of the following values:","0 or smua.DISABLE: Disables high-capacitance mode","1 or smua.ENABLE: Enables high-capacitance mode","Details","When enabled, the high-capacitance mode has the following effects on the SMU settings:","smua.measure.autorangei is set to smua.AUTORANGE_FOLLOW_LIMIT and cannot be changed","Current ranges below 1 µA are not accessible","If smua.source.limiti is less than 1 µA, it is raised to 1 µA","If smua.source.rangei is less than 1 µA, it is raised to 1 µA","If smua.source.lowrangei is less than 1 µA, it is raised to 1 µA","If smua.measure.lowrangei is less than 1 µA, it is raised to 1 µA","@High-capacitance mode is not available when the pulser is enabled.","Example","smua.source.highc = smua.ENABLE","Activates high-capacitance mode.","Also see","High-capacitance mode","smua.source.highc","15145.htm"); +Page[333]=new Array("This attribute sets the source level.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","0","Usage","sourceLevel = smua.source.levelY","smua.source.levelY = sourceLevel","sourceLevel","The source value; set to one of the following values:","Voltage: 0 V to ±40 V","Current when the pulser is disabled: 0 A to ±3 A","Bias current when the pulser is enabled: 0 A to ±250 mA","Y","SMU source function (v = voltage, i = current)","Details","This attribute configures the output level of the voltage or current source.","If the source is configured as a voltage source and the output is on, the new smua.source.levelv setting is sourced immediately. If the output is off or the source is configured as a current source, the voltage level is sourced when the source is configured as a voltage source and the output is turned on.","If the source is configured as a current source and the output is on, the new smua.source.leveli setting is sourced immediately. If the output is off or the source is configured as a voltage source, the current level is sourced when the source is configured as a current source and the output is turned on.","The sign of sourceLevel dictates the polarity of the source. Positive values generate positive voltage or current from the high terminal of the source relative to the low terminal. Negative values generate negative voltage or current from the high terminal of the source relative to the low terminal.","The reset() function sets the source levels to 0 V and 0 A.","Example","smua.source.levelv = 1","Sets voltage source of SMU channel A to 1 V.","Also see","smua.source.compliance","smua.source.func","smua.source.output","Source-measure concepts","smua.source.levelY","92361.htm"); +Page[334]=new Array("This attribute sets compliance limits.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","Limit voltage: 40 (40 V)
Limit current: 1 (1 A)
Limit power: 0 (disabled)","Usage","limit = smua.source.limitY","smua.source.limitY = limit","limit","The compliance limit value; set to one of the following values:","Voltage compliance: 10 mV to 40 V","Current compliance: 10 nA to 3 A","Power compliance (in watts)","Y","SMU function (v = voltage, i = current, p = power)","Details","Use the smua.source.limiti attribute to limit the current output of the voltage source. Use smua.source.limitv to limit the voltage output of the current source. The SMU always uses autoranging for the limit setting. Use the smua.source.limitp attribute to limit the output power of the source.","This attribute should be set in the test sequence before the turning the source on.","Using a limit value of 0 results in error code 1102, "Parameter too small," for v and i. Setting this attribute to zero disables power compliance for p. When setting the power compliance limit to a nonzero value, the SMU adjusts the source limit where appropriate to limit the output to the specified power. The SMU uses the lower of the programmed compliance value (the compliance level that would be used if power compliance were disabled) or the limit calculated from the power compliance setting.","Reading this attribute indicates the presently set compliance value. Use smua.source.compliance to read the state of source compliance.","Example","smua.source.limitv = 15","Sets the voltage limit to 15 V.","Also see","DUT test connections","smua.source.compliance","smua.source.func","smua.source.output","smua.source.limitY","92359.htm"); +Page[335]=new Array("This attribute sets the lowest source range that is used during autoranging.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","Voltage: 100e‑3 (100 mV)
Current: 100e‑9 (100 nA)","Usage","sourceRangeLow = smua.source.lowrangeY","smua.source.lowrangeY = sourceRangeLow","sourceRangeLow","Set to the lowest voltage (in volts) or current (in amperes) range to be used","Y","SMU source function (v = voltage, i = current)","Details","This attribute is used with source autoranging to put a lower bound on the range that is used. Lower ranges generally require greater settling times. If you set a low-range value, you might be able to source small values with less settling time.","If the instrument is set to autorange and it is on a range lower than the one specified by sourceRangeLow, the source range will be changed to the range specified by sourceRangeLow.","Example","smua.source.lowrangev = 1","Sets the voltage low range to 1 V. This prevents the source from using the 100 mV range when sourcing voltage.","Also see","smua.source.autorangeY","smua.source.lowrangeY","92358.htm"); +Page[336]=new Array("This attribute sets the source function that is used (source 0 A or 0 V) when the output is turned off and the source‑measure unit (SMU) is in normal output-off mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","1 (smua.OUTPUT_DCVOLTS)","Usage","offfunc = smua.source.offfunc","smua.source.offfunc = offfunc","offfunc","Set to the source function to be used when the output is off and the SMU is in normal output-off mode. Set to one of the following values:","0 or smua.OUTPUT_DCAMPS: Source 0 A","1 or smua.OUTPUT_DCVOLTS: Source 0 V","Details","This attribute controls the source function used when the output is turned off and smua.source.offmode is set to smua.OUTPUT_NORMAL.","Set this attribute to smua.OUTPUT_DCVOLTS for the source to be a 0 V source when the output is off (smua.source.offlimiti is used).","Set it to smua.OUTPUT_DCAMPS for the source to be a 0 A source when the output is off (smua.source.offlimitv is used).","@If the pulser is enabled and the output‑off mode is set to normal, the smua.source.offfunc setting is ignored and the output circuit is shorted.","Example","smua.source.offmode = smua.OUTPUT_NORMAL","smua.source.offfunc = smua.OUTPUT_DCVOLTS","Sets the normal output-off mode to source 0 V when the output is turned off.","Also see","Output-off states","smua.source.offlimitY","smua.source.offmode","smua.source.output","smua.source.offfunc","92715.htm"); +Page[337]=new Array("This attribute sets the limit (current or voltage) used when the source‑measure unit (SMU) is in normal output-off mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","Current: 1e-3 (1 mA)
Voltage: 40 (40 V)","Usage","sourceLimit = smua.source.offlimitY","smua.source.offlimitY = sourceLimit","sourceLimit","Set to the limit to be used when the SMU is in normal output-off mode","Y","SMU source function (v = voltage, i = current)","Details","Setting the current limit to lower than 1 mA may interfere with operation of the contact check function. See smua.contact.check() and smua.contact.r() for details.","Example","smua.source.offlimiti = 10e-3","Changes the normal output-off mode limit to 10 mA.","Also see","smua.contact.check()","smua.contact.r()","smua.source.offfunc","smua.source.offmode","smua.source.offlimitY","15149.htm"); +Page[338]=new Array("This attribute sets the source output-off mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","0 (smua.OUTPUT_NORMAL)","Usage","sourceOffMode = smua.source.offmode","smua.source.offmode = sourceOffMode","sourceOffMode","The output-off setting; set to one of the following values:","0 or smua.OUTPUT_NORMAL: See Details","1 or smua.OUTPUT_ZERO: See Details","2 or smua.OUTPUT_HIGH_Z: Opens the output relay when the output is turned off","Details","Reading this attribute returns the output-off mode of the source. Setting this attribute configures the SMU output-off mode.","When smua.OUTPUT_NORMAL is selected and the pulser is disabled, the source function is configured according to the smua.source.offfunc attribute. The smua.source.offfunc attribute controls whether the SMU is configured as a 0 V voltage source or a 0 A current source. When the SMU is operating as a 0 A current source, the smua.source.offlimitv attribute sets the voltage limit (similar to how the smua.source.offlimiti attribute sets the current limit when the SMU is operating as a 0 V voltage source).","When the output‑off mode is set to smua.OUTPUT_ZERO and the pulser is disabled, the source is configured to output 0 V. This is equivalent to smua.OUTPUT_NORMAL mode with smua.source.offfunc = smua.OUTPUT_DCVOLTS. If the source function is voltage, the current limit is not changed. If the source function is current, the current limit is set to the current source level or 10% of the current source range, whichever is greater.","When smua.OUTPUT_NORMAL or smua.OUTPUT_ZERO is selected and the pulser is enabled, the output circuit is shorted.","When sourceOffMode is set to smua.OUTPUT_HIGH_Z, the SMU opens the output relay when the output is turned off. To prevent excessive wear on the output relay, do not use this output-off mode for tests that turn the output off and on frequently.","Example","smua.source.offmode = smua.OUTPUT_HIGH_Z","Sets the output‑off mode to open the output relay when the output is turned off.","Also see","Output-off states","smua.source.offfunc","smua.source.offlimitY","smua.source.output","smua.source.offmode","92521.htm"); +Page[339]=new Array("This attribute enables or disables the source output.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.OUTPUT_OFF)","Usage","sourceOutput = smua.source.output","smua.source.output = sourceOutput","sourceOutput","The output state setting of the source; set to one of the following values:","0 or smua.OUTPUT_OFF: Turns off the source output","1 or smua.OUTPUT_ON: Turns on the source output","2 or smua.OUTPUT_HIGH_Z: Turns off the output in high Z mode (allows you to go to high Z mode without first setting the smua.source.offmode attribute to smua.OUTPUT_HIGH_Z)","Details","Reading this attribute returns the output state of the source. Setting this attribute switches the output of the source on or off.","When the output is switched on, the SMU sources either voltage or current, as set by smua.source.func.","Setting this attribute to smua.OUTPUT_HIGH_Z causes the output to turn off and go to the High Z mode. If the smua.source.output is read after setting this attribute to smua.OUTPUT_HIGH_Z, it returns 0.","Example","smua.source.output = smua.OUTPUT_ON","Turns on the source output.","Also see","DUT test connections","smua.source.func","smua.source.offmode","smua.source.output","15151.htm"); +Page[340]=new Array("This attribute contains the source range.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","Voltage: 100e-3 (100 mV)
Current: 100e-9 (100 nA)","Usage","rangeValue = smua.source.rangeY","smua.source.rangeY = rangeValue","rangeValue","Set to the maximum expected voltage or current to be sourced","Y","SMU source function (v = voltage, i = current)","Details","This attribute contains a value that sets the source‑measure unit (SMU) to a fixed range large enough to source the value. When read, the attribute contains the range the instrument is presently on when in autorange.","Assigning a value to this attribute sets the SMU to a fixed range large enough to source the assigned value. The instrument selects the best range for sourcing a value of rangeValue.","Reading this attribute returns the positive full-scale value of the source range the SMU is currently using. With source autoranging enabled, the output level controls the range. Querying the range after the level is set returns the range the instrument chose as appropriate for that source level.","This attribute is primarily intended to eliminate the time required by the automatic range selection performed by a sourcing instrument. Because selecting a fixed range prevents autoranging, an overrange condition can occur. For example, sourcing 10.0 V on the 2601B-PULSE 6 V range causes an overrange condition.","Example","smua.source.rangev = 1","Selects the 1 V source range.","Also see","Range","reset()","setup.recall()","smua.measure.rangeY","smua.reset()","smua.source.autorangeY","smua.source.rangeY","92312.htm"); +Page[341]=new Array("This attribute contains the source settling mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.SETTLE_SMOOTH)","Usage","settleOption = smua.source.settling","smua.source.settling = settleOption","settleOption","Set to the source settling mode. Set to one of the following values:","0 or smua.SETTLE_SMOOTH: Turns off additional settling operations (default)","1 or smua.SETTLE_FAST_RANGE: Instructs the source‑measure unit (SMU) to use a faster procedure when changing ranges","2 or smua.SETTLE_FAST_POLARITY: Instructs the SMU to change polarity without going to zero","3 or smua.SETTLE_DIRECT_IRANGE: Instructs the SMU to change the current range directly","128 or smua.SETTLE_FAST_ALL: Enables all smua.SETTLE_FAST_* operations","Details","Using smua.SETTLE_FAST_RANGE may cause the SMU to exceed the range change overshoot specification.","smua.SETTLE_FAST_POLARITY does not go to zero when changing polarity and may create inconsistencies at the zero crossing.","smua.SETTLE_DIRECT_IRANGE switches the SMU directly to the target range instead of the default range-by-range method. This option is mutually exclusive of any other smua.SETTLE_FAST_* commands.","Example","smua.source.settling = smua.SETTLE_FAST_POLARITY","Selects fast polarity changing.","Also see","Range","smua.source.settling","92343.htm"); +Page[342]=new Array("This attribute turns sink mode on or off.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Saved setup","0 (smua.DISABLE)","Usage","sinkMode = smua.source.sink","smua.source.sink = sinkMode","sinkMode","Sets the sink mode on or off; set to one of the following values:","0 or smua.DISABLE: Turns off sink mode","1 or smua.ENABLE: Turns on sink mode","Details","This attribute enables or disables sink mode. When sink mode is enabled, it reduces the source limit inaccuracy that occurs when operating in quadrants II and IV (quadrants I and III will show this source limit inaccuracy).","Example","smua.source.sink = smua.ENABLE","Enables sink mode.","Also see","Source or sink","smua.source.sink","15155.htm"); +Page[343]=new Array("This attribute sets the arm count in the trigger model.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","1","Usage","triggerArmCount = smua.trigger.arm.count","smua.trigger.arm.count = triggerArmCount","triggerArmCount","The arm count in the trigger model","Details","During a sweep, the SMU iterates through the arm layer of the trigger model this many times. After performing this many iterations, the SMU returns to an idle state.","If this count is set to zero, the SMU stays in the trigger model indefinitely until aborted.","Example","smua.trigger.arm.count = 5","Sets the SMU to iterate through the arm layer of the trigger model five times and then return to the idle state.","Also see","smua.trigger.count","smua.trigger.arm.count","15156.htm"); +Page[344]=new Array("This function sets the arm event detector to the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.arm.set()","Details","The SMU automatically clears all the event detectors when the smua.trigger.initiate() function is executed. This function should be called after the sweep is initiated.","A common example of when this function can be used is when you want the SMU to immediately perform an action the first time through the trigger model even if a programmed trigger event does not occur. ","This function can also be used to start actions on the SMU in case of a missed trigger event.","Example","smua.trigger.arm.set()","Sets the arm event detector to the detected state.","Also see","smua.trigger.initiate()","smua.trigger.measure.set()","smua.trigger.source.set()","smua.trigger.arm.set()","15157.htm"); +Page[345]=new Array("This attribute selects the event that will cause the arm event detector to enter the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0","Usage","eventID = smua.trigger.arm.stimulus","smua.trigger.arm.stimulus = eventID","eventID","Event that triggers the arm detector","Details","Set this attribute to the event ID of any trigger event generator to wait for that event.","Set this attribute to zero to bypass waiting for events at the arm event detector (the SMU continues uninterrupted through the remote trigger model). Set eventID to one of the existing trigger event IDs shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Example","smua.trigger.arm.stimulus = trigger.timer[1].EVENT_ID","An event on trigger timer 1 causes the arm event detector to enter the detected state.","Also see","Triggering","smua.trigger.arm.stimulus","15158.htm"); +Page[346]=new Array("This constant contains the number of the armed event.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = smua.trigger.ARMED_EVENT_ID","eventID","The armed event number","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to armed events from this SMU.","Example","trigger.timer[1].stimulus = smua.trigger.ARMED_EVENT_ID","Trigger timer when the SMU passes through the arm layer.","Also see","Triggering","smua.trigger.ARMED_EVENT_ID","15159.htm"); +Page[347]=new Array("This attribute turns automatic clearing of the event detectors on or off.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.DISABLE)","Usage","autoClear = smua.trigger.autoclear","smua.trigger.autoclear = autoClear","autoClear","Auto clear setting; set to one of the following values:","0 or smua.DISABLE: Turns off automatic clearing of the event detectors","1 or smua.ENABLE: Turns on automatic clearing of the event detectors","Details","This attribute enables or disables automatic clearing of the trigger model state machine event detectors when the SMU transitions from the arm layer to the trigger layer.","Only the detected states of the event detectors are cleared.","The overrun statuses of the event detectors are not automatically cleared when the SMU transitions from the arm layer to the trigger layer.","The event detectors are always cleared when a sweep is initiated.","Example","smua.trigger.autoclear = smua.ENABLE","Automatically clear the event detectors for the trigger mode state.","Also see","Triggering","smua.trigger.autoclear","15160.htm"); +Page[348]=new Array("This attribute sets the trigger count in the trigger model.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","1","Usage","triggerCount = smua.trigger.count","smua.trigger.count = triggerCount","triggerCount","The trigger count is the number of times the source‑measure unit (SMU) will iterate in the trigger layer for any given sweep","Details","During a sweep, the SMU iterates through the trigger layer of the trigger model this many times. After performing this many iterations, the SMU returns to the arm layer.","If this count is set to zero (0), the SMU stays in the trigger model indefinitely until aborted.","Example","reset()","period_timer = trigger.timer[1]","pulse_timer = trigger.timer[2]","smua.trigger.source.listv( {5} )","smua.trigger.source.action = smua.ENABLE","smua.source.rangev = 5","smua.trigger.measure.action = smua.DISABLE","pulse_timer.delay = 0.0006","pulse_timer.stimulus = period_timer.EVENT_ID","pulse_timer.count = 1","period_timer.delay = 0.005","period_timer.count = 9","period_timer.stimulus = smua.trigger.SWEEPING_EVENT_ID","period_timer.passthrough = true","smua.trigger.source.stimulus = period_timer.EVENT_ID","smua.trigger.endpulse.action = smua.SOURCE_IDLE","smua.trigger.endpulse.stimulus = pulse_timer.EVENT_ID","smua.trigger.count = 1","smua.trigger.arm.count = 10","smua.source.output = smua.OUTPUT_ON","smua.trigger.initiate()","waitcomplete()","smua.source.output = smua.OUTPUT_OFF","Generate a 10-point pulse train where each pulse has a width of 600 µs and a pulse period of 5 ms.","Alias the trigger timers to use for pulse width and period.","Create a fixed level voltage sweep.","Set the pulse width and trigger the pulse width timer with a period timer.","Set the pulse period to output one pulse per period and the count to generate 10 pulses.","Trigger the pulse period timer when a sweep is initiated.","Configure the timer to output a trigger event when it starts the first delay.","Trigger the SMU source action using pulse period timer.","Trigger the SMU end pulse action using pulse width timer.","Set the trigger model counts.","Configure the SMU to execute a 10-point pulse train.","Start the trigger model.","Wait for the sweep to complete.","Also see","Triggering","smua.trigger.count","15161.htm"); +Page[349]=new Array("This attribute enables or disables pulse sweeps when the pulser is disabled.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","1 (smua.SOURCE_HOLD)","Usage","pulseAction = smua.trigger.endpulse.action","smua.trigger.endpulse.action = pulseAction","pulseAction","The pulse mode setting; set to one of the following values (see Details for definition):","0 or smua.SOURCE_IDLE","1 or smua.SOURCE_HOLD","Details","When set to smua.SOURCE_HOLD, this attribute disables pulse mode sweeps, holding the source level for the remainder of the step. ","When set to smua.SOURCE_IDLE, this attribute enables pulse mode sweeps, setting the source level to the programmed (idle) level at the end of the pulse.","You cannot use this attribute and smua.trigger.source.pulsewidth in the same trigger model.","When the pulser is enabled, this setting is ignored. The source level is set to the programmed idle level at the end of the pulse.","Example","smua.trigger.endpulse.action = smua.SOURCE_IDLE","smua.trigger.endpulse.stimulus = trigger.timer[1].EVENT_ID","Configure the end pulse action to achieve a pulse and configure trigger timer 1 to control the end of pulse.","Also see","smua.trigger.source.pulsewidth","Triggering","smua.trigger.endpulse.action","92540.htm"); +Page[350]=new Array("This function sets the end pulse event detector to the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.endpulse.set()","Details","This function sets the end pulse event detector to the detected state.","The SMU automatically clears all the event detectors when the smua.trigger.initiate() function is executed. Therefore, smua.trigger.endpulse.set() should be called after the sweep is initiated. If the event detectors are configured to clear automatically because the smua.trigger.autoclear attribute is set to smua.ENABLE, make sure that smua.trigger.endpulse.set() is issued after the SMU has entered the trigger layer.","Example","reset()","period_timer = trigger.timer[1]","pulse_timer = trigger.timer[2]","smua.trigger.source.listv( {5} )","smua.trigger.source.action = smua.ENABLE","smua.source.rangev = 5","smua.trigger.measure.action = smua.DISABLE","pulse_timer.delay = 0.0006","pulse_timer.stimulus = period_timer.EVENT_ID","pulse_timer.count = 1","period_timer.delay = 0.005","period_timer.count = 9","period_timer.stimulus = smua.trigger.SWEEPING_EVENT_ID","period_timer.passthrough = true","smua.trigger.source.stimulus = period_timer.EVENT_ID","smua.trigger.endpulse.action = smua.SOURCE_IDLE","smua.trigger.endpulse.stimulus = pulse_timer.EVENT_ID","smua.trigger.count = 1","smua.trigger.arm.count = 10","smua.source.output = smua.OUTPUT_ON","smua.trigger.initiate()","waitcomplete()","smua.source.output = smua.OUTPUT_OFF","Generate a 10-point pulse train where each pulse has a width of 600 µs and a pulse period of 5 ms.","Alias the trigger timers to use for pulse width and period.","Create a fixed level voltage sweep.","Set the pulse width and trigger the pulse width timer with a period timer.","Set the pulse period to output one pulse per period and the count to generate 10 pulses.","Trigger the pulse period timer when a sweep is initiated.","Configure the timer to output a trigger event when it starts the first delay.","Trigger the SMU source action using pulse period timer.","Trigger the SMU end pulse action using pulse width timer.","Set the trigger model counts.","Configure the SMU to execute a 10-point pulse train.","Start the trigger model.","Wait for the sweep to complete.","Also see","smua.trigger.autoclear","smua.trigger.initiate()","Triggering","smua.trigger.endpulse.set()","15163.htm"); +Page[351]=new Array("This attribute defines which event will cause the end pulse event detector to enter the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0","Usage","eventID = smua.trigger.endpulse.stimulus","smua.trigger.endpulse.stimulus = eventID","eventID","Set to the event that triggers the end pulse action of the source","Details","Set this attribute to the event ID of any trigger event generator to wait for that event. To bypass waiting for an event, set this value of this attribute to 0. Set eventID to one of the existing trigger event IDs, which are shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Example","smua.trigger.endpulse.action = smua.SOURCE_IDLE","smua.trigger.endpulse.stimulus = trigger.timer[1].EVENT_ID","Configure the end pulse action to achieve a pulse and select the event, trigger.timer[1].EVENT_ID, that causes the arm event detector to enter the detected state.","Also see","Triggering","smua.trigger.endpulse.stimulus","15165.htm"); +Page[352]=new Array("This attribute sets the action of the source at the end of a sweep.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.SOURCE_IDLE)","Usage","action = smua.trigger.endsweep.action","smua.trigger.endsweep.action = action","action","The source action at the end of a sweep; set to one of the following values:","0 or smua.SOURCE_IDLE: Sets the source level to the programmed (idle) level at the end of the sweep","1 or smua.SOURCE_HOLD: Sets the source level to stay at the level of the last step","Details","Use this attribute to configure the source action at the end of the sweep. The SMU can be programmed to return to the idle source level or hold the last value of the sweep.","Example","smua.trigger.endsweep.action = smua.SOURCE_IDLE","Sets SMU return the source back to the idle source level at the end of a sweep.","Also see","Triggering","smua.trigger.endsweep.action","15166.htm"); +Page[353]=new Array("This constant contains the idle event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = smua.trigger.IDLE_EVENT_ID","eventID","The idle event number","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to idle events from this SMU.","Example","trigger.timer[1].stimulus = smua.trigger.IDLE_EVENT_ID","Trigger timer 1 when the SMU returns to the idle layer.","Also see","Triggering","smua.trigger.IDLE_EVENT_ID","15167.htm"); +Page[354]=new Array("This function initiates a sweep operation.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.initiate()","Details","This function causes the SMU to clear the four trigger model event detectors and enter its trigger model (moves the SMU from the idle state into the arm layer).","To perform source actions during the sweep, before calling this function, it is necessary to configure and enable one of the following sweep source actions:","smua.trigger.source.linearY()","smua.trigger.source.listY()","smua.trigger.source.logY()","To make measurements during the sweep, you must also configure and enable the measure action using smua.trigger.measure.Y().","If you run this function more than once without reconfiguring the sweep measurements, the caches on the configured measurement reading buffers will hold stale data; use the bufferVar.clearcache() function to remove stale values from the reading buffer cache.","This function initiates an overlapped operation.","Example","smua.trigger.initiate()","Starts a preconfigured sweep and clears the event detectors.","Also see","bufferVar.clearcache()","Configuring and running sweeps","smua.trigger.measure.action","smua.trigger.measure.Y()","smua.trigger.source.action","smua.trigger.source.linearY()","smua.trigger.source.listY()","smua.trigger.source.logY()","Triggering","smua.trigger.initiate()","15168.htm"); +Page[355]=new Array("This attribute controls measurement actions during a sweep.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.DISABLE)","Usage","action = smua.trigger.measure.action","smua.trigger.measure.action = action","action","The sweep measurement action; set to one of the following values:","0 or smua.DISABLE: Do not make measurements during the sweep","1 or smua.ENABLE: Make measurements during the sweep","2 or smua.ASYNC: Make measurements during the sweep, but asynchronously with the source area of the trigger model","Details","With this attribute enabled (setting action to smua.ENABLE or smua.ASYNC), configure the measurement with one of the smua.trigger.measure.Y() functions.","If this attribute is set to smua.ASYNC:","Asynchronous sweep measurements can only be used with measure autoranging turned off. To turn measure autoranging off for all measurements during the sweep, set the smua.measure.autorangeY attribute to smua.AUTORANGE_OFF.","Autozero must also be turned off. To turn off autozero, set the smua.measure.autozero attribute to smua.AUTOZERO_OFF or smua.AUTOZERO_ONCE.","The reading buffer used by smua.trigger.measure.Y() must have bufferVar.collectsourcevalues set to 0.","If any of the above items is incorrectly configured, the smua.trigger.initiate() function generates an error.","Example","smua.trigger.measure.v(smua.nvbuffer1)","smua.trigger.measure.action = smua.ENABLE","Configure sweep voltage measurements.","Enable voltage measurements during the sweep.","Also see","bufferVar.collectsourcevalues","smua.trigger.autoclear","smua.trigger.measure.Y()","Triggering","smua.trigger.measure.action","15169.htm"); +Page[356]=new Array("This function sets the measurement event detector to the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.measure.set()","Details","This function is useful whenever you want the SMU to continue operation without waiting for a programmed trigger event. When called, this function immediately satisfies the event detector, allowing the SMU to continue through the trigger model.","For example, you might use this function to have the SMU immediately perform an action the first time through the trigger model, even if a programmed trigger event does not occur.","If the event detectors are configured to clear automatically because the smua.trigger.autoclear attribute is set to smua.ENABLE, make sure that smua.trigger.measure.set() is issued after the SMU has entered the trigger layer. This function can also be used to start actions on the SMU in case of a missed trigger event.","The SMU automatically clears all event detectors when the smua.trigger.initiate() function is executed. This function should be called after the sweep is initiated.","Example","smua.trigger.measure.set()","Sets the measure event detector.","Also see","smua.trigger.arm.set()","smua.trigger.autoclear","smua.trigger.endpulse.set()","smua.trigger.source.set()","smua.trigger.measure.set()","15170.htm"); +Page[357]=new Array("This attribute selects the event that causes the measure event detector to enter the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0","Usage","eventID = smua.trigger.measure.stimulus","smua.trigger.measure.stimulus = eventID","eventID","Event that triggers the measurement detector","Details","Set this attribute to the event ID of any trigger event generator to wait for that event. When set, the SMU waits for the event at the measurement event detector portion of the trigger model.","Set this attribute to zero to bypass waiting for an event (the SMU continues uninterrupted through the remote trigger model). Set eventID to one of the existing trigger event IDs shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Example","smua.trigger.measure.stimulus = trigger.timer[1].EVENT_ID","Sets delay before measurement begins.","Also see","Triggering","smua.trigger.measure.stimulus","15171.htm"); +Page[358]=new Array("This function configures the measurements that are to be made in a subsequent sweep.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.measure.Y(rbuffer)","smua.trigger.measure.iv(ibuffer, vbuffer)","Y","SMU measurement type (v = voltage, i = current, r = resistance, p = power)","rbuffer","A reading buffer object where the readings will be stored","ibuffer","A reading buffer object where current readings will be stored","vbuffer","A reading buffer object where voltage readings will be stored","Details","As measurements are made, they are stored in a reading buffer. If the instrument is configured to return multiple readings where one is requested, the readings are available as they are made. Measurements are in the following units of measure: v = volts, i = amperes, r = ohms, p = watts.","The smua.trigger.measure.iv() function stores current readings in ibuffer and voltage readings in vbuffer.","If a given reading buffer contains any data, it is cleared before making any measurements, unless the reading buffer has been configured to append data.","The SMU only retains the last call to any one of these functions and only that measurement action is performed.","After configuring the measurements to make with this function, enable the measurement action.","Example","smua.trigger.measure.v(vbuffername)","smua.trigger.measure.action = smua.ENABLE","Stores voltage readings during the sweep in buffer vbuffername.","Also see","Reading buffers","smua.measure.Y()","smua.nvbufferY","smua.trigger.measure.action","Sweep Operation","Triggering","waitcomplete()","smua.trigger.measure.Y()","15172.htm"); +Page[359]=new Array("This constant contains the measurement complete event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = smua.trigger.MEASURE_COMPLETE_EVENT_ID","eventID","The measurement complete event number","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to measure complete events from this SMU.","Example","trigger.timer[1].stimulus = smua.trigger.MEASURE_COMPLETE_EVENT_ID","Trigger the timer when the SMU completes a measurement.","Also see","Triggering","smua.trigger.MEASURE_COMPLETE_EVENT_ID","15173.htm"); +Page[360]=new Array("This constant contains the pulse complete event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = smua.trigger.PULSE_COMPLETE_EVENT_ID","eventID","The pulse complete event number","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to pulse complete events.","Example","trigger.timer[1].stimulus = smua.trigger.PULSE_COMPLETE_EVENT_ID","Trigger a timer when the SMU completes a pulse.","Also see","Triggering","smua.trigger.PULSE_COMPLETE_EVENT_ID","15174.htm"); +Page[361]=new Array("This attribute enables or disables sweeping the source (on or off).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.DISABLE)","Usage","action = smua.trigger.source.action","smua.trigger.source.action = action","action","Sweep source action. Set to one of the following values:","0 or smua.DISABLE: Do not sweep the source","1 or smua.ENABLE: Sweep the source","Details","This attribute is used to enable or disable source level changes during a sweep. In addition to enabling the action before initiating the sweep, make sure to configure it using smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY().","Example","smua.trigger.source.listv({3, 1, 4, 5, 2})","smua.trigger.source.action = smua.ENABLE","Configure list sweep (sweep through 3 V, 1 V, 4 V, 5 V, and 2 V).","Enable the source action.","Also see","smua.trigger.source.linearY()","smua.trigger.source.listY()","smua.trigger.source.logY()","Triggering","smua.trigger.source.action","15178.htm"); +Page[362]=new Array("This attribute sets the sweep source limit.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0 (smua.LIMIT_AUTO)","Usage","sweepSourceLimit = smua.trigger.source.limitY","smua.trigger.source.limitY = sweepSourceLimit","sweepSourceLimit","The source limit that is used during triggered operation; set to:","A user-defined value","smua.LIMIT_AUTO","Y","SMU output function (v = voltage, i = current)","Details","Use this attribute to perform extended operating area (EOA) pulse mode sweeps.","If this attribute is set to smua.LIMIT_AUTO (or 0), the SMU uses the normal limit setting during sweeping. If this attribute is set to any other numeric value, the SMU switches in this limit at the start of the source action and returns to the normal limit setting at the end of the end pulse action.","Normally, the limit range is automatically adjusted in accordance with the limit value. During sweeping, however, the limit range is fixed to avoid the delays associated with changing range. This fixed limit range is determined by the maximum limit value needed during the sweep; that is, the greater of either the normal limit value (as specified by smua.source.limitY) or the sweep limit value (as specified by smua.trigger.source.limitY). Note that the minimum limit value that can be enforced during the sweep is equal to 10% of the full scale value of the fixed limit range. If the smaller limit value (normal or sweep) falls below this 10% threshold, the 10% value is enforced instead. Likewise, if the limit value falls below the 10% threshold as a result of power compliance, the 10% value is enforced instead.","When using the EOA, the SMU will automatically start the end pulse action if the SMU is not triggered before its maximum pulse width. It will also delay the source action if necessary to limit the pulse duty cycle to stay within the capabilities of the SMU.","Example","smua.trigger.source.limitv = 10","Sets the voltage sweep limit to 10 V.","Also see","Configuring and running sweeps","smua.source.limitY","Triggering","smua.trigger.source.limitY","15179.htm"); +Page[363]=new Array("This function configures a linear source sweep.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.source.linearY(startValue, endValue, points)","Y","SMU source function (v = voltage, i = current)","startValue","Source value of the first point","endValue","Source value of the last point","points","The number of points used to calculate the step size","Details","This function configures the source action to be a linear source sweep in a subsequent sweep. During the sweep, the source will generate a uniform series of ascending or descending voltage or current changes called steps. The number of source steps is one less than the number of sourced points.","The points parameter does not set the number of steps in a sweep, but rather is used to calculate source values within a subsequent sweep. If the subsequent sweep has more points than specified in points, the source will restart at the beginning. This means that if the trigger count is greater than the number of points in a sweep as configured, the SMU will satisfy the trigger count by restarting the sweep values from the beginning. ","If the subsequent sweep has fewer points than specified in points, endValue will not be reached during the sweep. This means that if the trigger count is less than the number of source values configured, the SMU will satisfy the trigger count and ignore the remaining source values.","In cases where the first sweep point is a nonzero value, it may be necessary to pre-charge the circuit so that the sweep will return a stable value for the first measured point without penalizing remaining points in the sweep.","With linear sweeps, it is acceptable to maintain a fixed source resolution over the entire sweep. To prevent source range changes during the sweep (especially when sweeping through 0.0), set the source range to a fixed range appropriate for the larger of either startValue or endValue. ","The SMU will only store the most recent configured source action. The last call to smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY() is used for the source action.","Source functions cannot be changed within a sweep.","After configuring the sweep source values, enable the source action by setting smua.trigger.source.action.","Example","smua.trigger.source.linearv(0, 10, 11)","Sweeps from 0 V to 10 V in 1 V steps.","Also see","smua.trigger.source.action","smua.trigger.source.listY()","smua.trigger.source.logY()","Sweep Operation","smua.trigger.source.linearY()","15180.htm"); +Page[364]=new Array("This function configures an array-based source sweep.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.source.listY(sweepList)","Y","SMU source function (v = voltage, i = current)","sweepList","An array of source values","Details","This function configures the source action to be a list sweep in a subsequent sweep. During the sweep, the source will output the sequence of source values given in the sweepList array.","If the subsequent sweep has more points than specified in sweepList, the source will restart at the beginning. This means that if the trigger count is greater than the number of points in a sweep as configured, the SMU will satisfy the trigger count by restarting the sweep values from the beginning. ","If the subsequent sweep has fewer points than specified in sweepList, the extra values will be ignored. This means that if the trigger count is less than the number of source values configured, the SMU will satisfy the trigger count and ignore the remaining source values.","In cases where the first sweep point is a nonzero value, it may be necessary to pre-charge the circuit so that the sweep will return a stable value for the first measured point without penalizing remaining points in the sweep.","The SMU will only store the most recent configured source action. The last call to smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY() is used for the source action.","Source functions cannot be changed within a sweep.","After configuring the sweep source values, enable the source action by setting smua.trigger.source.action.","Example","smua.trigger.source.listv({3, 1, 4, 5, 2})","Sweeps through 3 V, 1 V, 4 V, 5 V, and 2 V.","Also see","smua.trigger.source.action","smua.trigger.source.linearY()","smua.trigger.source.logY()","Sweep Operation","smua.trigger.source.listY()","15181.htm"); +Page[365]=new Array("This function configures an exponential (geometric) source sweep.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.source.logY(startValue, endValue, points, asymptote)","Y","SMU source function (v = voltage, i = current)","startValue","Source value of the first point","endValue","Source value of the last point","points","The number of points used to calculate the step size","asymptote","The asymptotic offset value","Details","This function configures the source action to be a geometric source sweep in a subsequent sweep. During the sweep, the source generates a geometric series of ascending or descending voltage or current changes called steps. Each step is larger or smaller than the previous step by a fixed proportion. The constant of proportionality is determined by the starting value, the ending value, the asymptote, and the number of steps in the sweep. The number of source steps is one less than the number of sourced points.","The points parameter does not set the number of steps in a sweep, but rather is used to calculate source values within a subsequent sweep. If the subsequent sweep has more points than specified in points, the source restarts at the beginning. This means that if the trigger count is greater than the number of points in a sweep as configured, the SMU satisfies the trigger count by restarting the sweep values from the beginning. ","If the subsequent sweep has fewer points than specified in points, endValue is not reached during the sweep. This means that if the trigger count is less than the number of source values configured, the SMU satisfies the trigger count and ignores the remaining source values.","In cases where the first sweep point is nonzero, it may be necessary to pre-charge the circuit so that the sweep returns a stable value for the first measured point without penalizing remaining points in the sweep.","With logarithmic sweeps, it is usually necessary to allow the source to autorange to maintain good source accuracy when sweeping over more than one decade or across range boundaries.","The asymptote parameter can be used to customize the inflection and offset of the source value curve. This allows log sweeps to cross zero. Setting this parameter to zero provides a conventional logarithmic sweep. The asymptote value is the value that the curve has at either positive or negative infinity, depending on the direction of the sweep.","The asymptote value must not be equal to or between the starting and ending values. It must be outside the range defined by the starting and ending values.","The SMU stores only the most recent configured source action. The last call to smua.trigger.source.linearY(), smua.trigger.source.listY(), or smua.trigger.source.logY() is used for the source action.","Source functions cannot be changed within a sweep.","After configuring the sweep source values, enable the source action by setting smua.trigger.source.action.","Example","smua.trigger.source.logv(1, 10, 11, 0)","Sweeps from 1 V to 10 V in 10 steps with an asymptote of 0 V.","Also see","smua.trigger.source.action","smua.trigger.source.linearY()","smua.trigger.source.listY()","Sweep operation","smua.trigger.source.logY()","15182.htm"); +Page[366]=new Array("This attribute sets the source pulse width when using a trigger model sweep when the pulser is enabled","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
SMU reset
Recall setup","Saved setup","0","Usage","pulsewidth = smua.trigger.source.pulsewidth","smua.trigger.source.pulsewidth = pulsewidth","pulsewidth","The source pulse width in seconds; set from 0.000001 to 0.065; set to 0 to disable automatic pulsewidth control","Details","Use this attribute only when generating pulses using the trigger model when the pulser is enabled.","Set the pulsewidth parameter to a nonzero value to limit the action of the source to the specified pulse width. This allows the 2601B-PULSE to generate pulses with less pulsewidth jitter than those generated using the end‑pulse trigger block in the trigger model.","The value set for this attribute affects the values you can use for the smua.pulser.measure.aperture and smu.pulser.measure.delay attributes. The sum of the measure delay and the aperture must be less than the specified pulse width.","You cannot use this attribute and smua.trigger.endpulse.action in the same trigger model.","Example","smua.trigger.source.pulsewidth = 50e-6","Set the source pulse width to 50 µs.","Also see","smua.pulser.measure.aperture","smua.pulser.measure.delay","smua.trigger.endpulse.action","smua.trigger.source.pulsewidth","91678.htm"); +Page[367]=new Array("This function sets the source event detector to the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","smua.trigger.source.set()","Details","This function sets the source event detector to the detected state.","The SMU automatically clears all event detectors when the smua.trigger.initiate() function is executed. This function should be called after the sweep is initiated. If the event detectors are configured to clear automatically because the smua.trigger.autoclear attribute is set to smua.ENABLE, make sure that smua.trigger.source.set() is issued after the SMU has entered the trigger layer.","Example","reset()","smua.trigger.source.listv({5})","smua.trigger.source.stimulus = display.trigger.EVENT_ID","smua.source.output = smua.OUTPUT_ON","smua.trigger.initiate()","delay(1)","-- Continue even if the display trigger key was not pressed.","smua.trigger.source.set()","waitcomplete()","Sets the source event detector.","Also see","smua.trigger.arm.set()","smua.trigger.autoclear","smua.trigger.endpulse.set()","smua.trigger.initiate()","smua.trigger.measure.set()","Triggering","smua.trigger.source.set()","15183.htm"); +Page[368]=new Array("This attribute defines which event causes the source event detector to enter the detected state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","SMU reset
Instrument reset
Recall setup","Not saved","0","Usage","eventID = smua.trigger.source.stimulus","smua.trigger.source.stimulus = eventID","eventID","Set to the event that triggers the end‑pulse source off action","Details","Set this attribute to the event ID of any trigger event generator to wait for that event. When set, the SMU waits for the event at the source event detector portion of the trigger model. To bypass waiting for an event, set the value of this attribute to zero (0). Set eventID to one of the existing trigger event IDs shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Example","smua.trigger.source.stimulus = digio.trigger[2].EVENT_ID","Configure to start its source action when a trigger event occurs on digital I/O line 2.","Also see","Triggering","smua.trigger.source.stimulus","15184.htm"); +Page[369]=new Array("This constant contains the source complete event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = smua.trigger.SOURCE_COMPLETE_EVENT_ID","eventID","The source action complete event number","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to source complete events from this source‑measure unit (SMU).","Example","trigger.timer[1].stimulus = smua.trigger.SOURCE_COMPLETE_EVENT_ID","Trigger the timer when the SMU updates the source level or starts a pulse.","Also see","Triggering","smua.trigger.SOURCE_COMPLETE_EVENT_ID","15175.htm"); +Page[370]=new Array("This constant contains the sweep complete event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = smua.trigger.SWEEP_COMPLETE_EVENT_ID","eventID","The sweep complete event number","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to sweep complete events from this SMU.","Example","digio.trigger[2].mode = digio.TRIG_RISINGA","digio.trigger[2].clear()","smua.trigger.source.stimulus = digio.trigger[2].EVENT_ID","digio.trigger[4].mode = digio.TRIG_RISINGM","digio.trigger[4].pulsewidth = 0.001","digio.trigger[4].stimulus = smua.trigger.SWEEP_COMPLETE_EVENT_ID","Configure the 2601B-PULSE to detect a rising edge on digital I/O line 2.","Configure SMU A to start its source action when a trigger event occurs on digital I/O line 2.","Configure digital I/O line 4 to output a 1 ms rising-edge trigger pulse at the completion of the SMU sweep.","Also see","Triggering","smua.trigger.SWEEP_COMPLETE_EVENT_ID","15176.htm"); +Page[371]=new Array("This constant contains the sweeping event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = smua.trigger.SWEEPING_EVENT_ID","eventID","The sweeping event number","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to sweeping events from this SMU.","Example","reset()","period_timer = trigger.timer[1]","pulse_timer = trigger.timer[2]","smua.trigger.source.listv( {5} )","smua.trigger.source.action = smua.ENABLE","smua.source.rangev = 5","smua.trigger.measure.action = smua.DISABLE","pulse_timer.delay = 0.0006","pulse_timer.stimulus = period_timer.EVENT_ID","pulse_timer.count = 1","period_timer.delay = 0.005","period_timer.count = 9","period_timer.stimulus = smua.trigger.SWEEPING_EVENT_ID","period_timer.passthrough = true","smua.trigger.source.stimulus = period_timer.EVENT_ID","smua.trigger.endpulse.action = smua.SOURCE_IDLE","smua.trigger.endpulse.stimulus = pulse_timer.EVENT_ID","smua.trigger.count = 1","smua.trigger.arm.count = 10","smua.source.output = smua.OUTPUT_ON","smua.trigger.initiate()","waitcomplete()","smua.source.output = smua.OUTPUT_OFF","Generate a 10-point pulse train where each pulse has a width of 600 µs and a pulse period of 5 ms.","Alias the trigger timers to use for pulse width and period.","Create a fixed level voltage sweep.","Set the pulse width and trigger the pulse width timer with a period timer.","Set the pulse period to output one pulse per period and the count to generate 10 pulses.","Trigger the pulse period timer when a sweep is initiated.","Configure the timer to output a trigger event when it starts the first delay.","Trigger the SMU source action using pulse period timer.","Trigger the SMU end pulse action using pulse width timer.","Set the trigger model counts.","Configure the SMU to execute a 10-point pulse train.","Start the trigger model.","Wait for the sweep to complete.","Also see","Triggering","smua.trigger.SWEEPING_EVENT_ID","15177.htm"); +Page[372]=new Array("This attribute stores the status byte condition register.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not saved","Not applicable","Usage","statusByte = status.condition","statusByte","The status byte; a zero (0) indicates no bits set; other values indicate various bit settings","Details","This attribute is used to read the status byte, which is returned as a numeric value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">","*","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","The returned value can indicate one or more status events occurred. When an enabled status event occurs, a summary bit is set in this register to indicate the event occurrence.","The individual bits of this register have the following meanings:","Bit","Value and description","B0","status.MEASUREMENT_SUMMARY_BIT","status.MSB","Set summary bit indicates that an enabled measurement event has occurred. ","Bit B0 decimal value: 1","B1","status.SYSTEM_SUMMARY_BIT","status.SSB","Set summary bit indicates that an enabled system event has occurred.","Bit B1 decimal value: 2","B2","status.ERROR_AVAILABLE","status.EAV","Set summary bit indicates that an error or status message is present in the Error Queue. ","Bit B2 decimal value: 4","B3","status.QUESTIONABLE_SUMMARY_BIT","status.QSB","Set summary bit indicates that an enabled questionable event has occurred. ","Bit B3 decimal value: 8","B4","status.MESSAGE_AVAILABLE","status.MAV","Set summary bit indicates that a response message is present in the Output Queue. ","Bit B4 decimal value: 16","B5","status.EVENT_SUMMARY_BIT","status.ESB","Set summary bit indicates that an enabled standard event has occurred. ","Bit B5 decimal value: 32","B6","status.MASTER_SUMMARY_STATUS","status.MSS","Request Service (RQS)/Master Summary Status (MSS). Depending on how it is used, bit B6 of the status byte register is either the Request for Service (RQS) bit or the Master Summary Status (MSS) bit:","When using the GPIB, USB, or VXI-11 serial poll sequence of the 2601B-PULSE to obtain the status byte (serial poll byte), B6 is the RQS bit. The set bit indicates that the Request Service (RQS) bit of the status byte (serial poll byte) is set and a service request (SRQ) has occurred. ","When using the status.condition register command or the *STB? common command to read the status byte, B6 is the MSS bit. Set bit indicates that an enabled summary bit of the status byte register is set.","Bit B6 decimal value: 64","B7","status.OPERATION_SUMMARY_BIT","status.OSB","Set summary bit indicates that an enabled operation event has occurred.","Bit B7 decimal value: 128","In addition to the above constants, when more than one bit of the register is set, statusByte equals the sum of their decimal weights. For example, if 129 is returned, bits B0 and B7 are set (1 + 128).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Example","statusByte = status.condition","print(statusByte)","Returns statusByte.","Sample output:","1.29000e+02","Converting this output (129) to its binary equivalent yields 1000 0001 ","Therefore, this output indicates that the set bits of the status byte condition register are presently B0 (MSS) and B7 (OSB).","Also see","Status byte and service request (SRQ)","status.condition","29255.htm"); +Page[373]=new Array("This attribute contains the measurement event register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","10,635 (All bits set)","Usage","measurementRegister = status.measurement.condition","measurementRegister = status.measurement.enable","measurementRegister = status.measurement.event","measurementRegister = status.measurement.ntr","measurementRegister = status.measurement.ptr","status.measurement.enable = measurementRegister","status.measurement.ntr = measurementRegister","status.measurement.ptr = measurementRegister","measurementRegister","The status of the measurement event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes read or write the measurement event registers.","Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. ","For example, assume value 257 is returned for the enable register. The binary equivalent is 0000 0001 0000 0001. This value indicates that bit B0 (VLMT) and bit B8 (BAV) are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","1","0","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","status.measurement.VOLTAGE_LIMIT","status.measurement.VLMT","Set bit is a summary of the status.measurement.voltage_limit register.","Bit B0 decimal value: 1","B1","status.measurement.CURRENT_LIMIT","status.measurement.ILMT","Set bit is a summary of the status.measurement.current_limit register.","Bit B1 decimal value: 2","B2","Not used","B3","status.measurement.PROTECTION","status.measurement.PROT","Set bit indicates that the pulser protection was tripped. Refer to smua.pulser.protect.tripped for events that can trip the protection circuits.","Bit B1 decimal value: 8","B4 to B6","Not used","B7","status.measurement.READING_OVERFLOW","status.measurement.ROF","Set bit is a summary of the status.measurement.reading_overflow register.","Bit B7 decimal value: 128","B8","status.measurement.BUFFER_AVAILABLE","status.measurement.BAV","Set bit is a summary of the status.measurement.buffer_available register.","Bit B8 decimal value: 256","B9 to B10","Not used","B11","status.measurement.INTERLOCK","status.measurement.INT","Interlock line. Set bit indicates that interlock is asserted.","Bit B11 decimal value: 2,048","B12","Not used","B13","status.measurement.INSTRUMENT_SUMMARY","status.measurement.INST","Set bit indicates that a bit in the measurement instrument summary register is set.","Bit B13 decimal value: 8,192","B14 to B15","Not used","As an example, to set bit B8 of the measurement event enable register, set status.measurement.enable = status.measurement.BAV. ","In addition to the above constants, measurementRegister can be set to the decimal equivalent of the bit to set. To set more than one bit of the register, set measurementRegister to the sum of their decimal weights. For example, to set bits B1 and B8, set measurementRegister to 258 (which is the sum of 2 + 256).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example","status.measurement.enable = status.measurement.BAV","Sets the BAV bit of the measurement event enable register.","Also see","Measurement event registers","smua.pulser.protect.tripped","status.measurement.*","92390.htm"); +Page[374]=new Array("This attribute contains the measurement event buffer available summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","measurementRegister = status.measurement.buffer_available.condition","measurementRegister = status.measurement.buffer_available.enable","measurementRegister = status.measurement.buffer_available.event","measurementRegister = status.measurement.buffer_available.ntr","measurementRegister = status.measurement.buffer_available.ptr","status.measurement.buffer_available.enable = measurementRegister","status.measurement.buffer_available.ntr = measurementRegister","status.measurement.buffer_available.ptr = measurementRegister","measurementRegister","The status of the measurement event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the measurement event buffer available summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.measurement.buffer_available.SMUA","Set bit indicates that there is at least one reading stored in either or both of the dedicated reading buffers.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the measurement event buffer available summary enable register, set status.measurement.buffer_available.enable = status.measurement.buffer_available.SMUA.","In addition to the above constants, measurementRegister can be set to the decimal equivalent of the bit to set.","Example 1","status.measurement.buffer_available.enable = status.measurement.buffer_available.SMUA","Uses the constant to set the SMUA bit of the measurement event buffer available summary enable register.","Example 2","status.measurement.buffer_available.enable = 2","Uses the decimal value to set the SMUA bit of the measurement event buffer available summary enable register.","Also see","Measurement event registers","status.measurement.buffer_available.*","93041.htm"); +Page[375]=new Array("This attribute contains the measurement event current limit summary registers.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","measurementRegister = status.measurement.current_limit.condition","measurementRegister = status.measurement.current_limit.enable","measurementRegister = status.measurement.current_limit.event","measurementRegister = status.measurement.current_limit.ntr","measurementRegister = status.measurement.current_limit.ptr","status.measurement.current_limit.enable = measurementRegister","status.measurement.current_limit.ntr = measurementRegister","status.measurement.current_limit.ptr = measurementRegister","measurementRegister","The status of the measurement event current limit summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the measurement event current limit summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.measurement.current_limit.SMUA","Set bit indicates that the SMU A current limit was exceeded.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the measurement event current limit summary enable register, set status.measurement.current_limit.enable = status.measurement.current_limit.SMUA.","In addition to the above constants, measurementRegister can be set to the decimal value of Bit B1.","Example 1","status.measurement.current_limit.enable = status.measurement.current_limit.SMUA","Sets the SMUA bit of the Measurement Event Current Limit Summary Enable Register using a constant.","Example 2","status.measurement.current_limit.enable = 2","Sets the SMUA bit of the Measurement Event Current Limit Summary Enable Register using a decimal value.","Also see","Measurement event registers","status.measurement.instrument.smua.*","status.measurement.current_limit.*","93040.htm"); +Page[376]=new Array("This attribute contains the registers of the measurement event instrument summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","measurementRegister = status.measurement.instrument.condition","measurementRegister = status.measurement.instrument.enable","measurementRegister = status.measurement.instrument.event","measurementRegister = status.measurement.instrument.ntr","measurementRegister = status.measurement.instrument.ptr","status.measurement.instrument.enable = measurementRegister","status.measurement.instrument.ntr = measurementRegister","status.measurement.instrument.ptr = measurementRegister","measurementRegister","The status of the measurement event instrument summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the measurement event instrument summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table. ","Bit","Value and description","B0","Not used","B1","status.measurement.instrument.SMUA","Set bit indicates one or more enabled bits of the measurement event SMU A summary register is set.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the measurement event instrument summary enable register, set status.measurement.instrument.enable = status.measurement.instrument.SMUA.","In addition to the constant, measurementRegister can be set to the decimal value of bit B1.","Example 1","status.measurement.instrument.enable = status.measurement.instrument.SMUA","Uses the constant to set the SMU A bit of the measurement event instrument summary enable register.","Example 2","status.measurement.instrument.enable = 2","Uses the decimal value to set the SMU A bit of the measurement event instrument summary enable register.","Also see","Measurement event registers","status.measurement.instrument.*","93039.htm"); +Page[377]=new Array("This attribute contains the registers of the measurement event SMU A summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","395 (All bits set) ","Usage","measurementRegister = status.measurement.instrument.smua.condition","measurementRegister = status.measurement.instrument.smua.enable","measurementRegister = status.measurement.instrument.smua.event","measurementRegister = status.measurement.instrument.smua.ntr","measurementRegister = status.measurement.instrument.smua.ptr","status.measurement.instrument.smua.enable = measurementRegister","status.measurement.instrument.smua.ntr = measurementRegister","status.measurement.instrument.smua.ptr = measurementRegister ","measurementRegister","The status of the instrument measurement status SMU summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the measurement event SMU summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, assume the value 257 is returned for the enable register. The binary equivalent is 0000 0001 0000 0001. This value indicates that bit B0 (VLMT) and bit B8 (BAV) are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","1","0","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0*","status.measurement.instrument.smua.VOLTAGE_LIMIT","status.measurement.instrument.smua.VLMT","Set bit indicates that the voltage limit was exceeded.","Bit B0 decimal value: 1","B1*","status.measurement.instrument.smua.CURRENT_LIMIT","status.measurement.instrument.smua.ILMT","Set bit indicates that the current limit was exceeded.","Bit B1 decimal value: 2","B2","Not used","B3","status.measurement.instrument.smua.PROTECTION","status.measurement.instrument.smua.PROT","Set bit indicates that the pulser protection was tripped. Refer to smua.pulser.protect.tripped for events that can trip the protection circuits.","Bit B0 decimal value: 8","B4 to B6","Not used","B7","status.measurement.instrument.smua.READING_OVERFLOW","status.measurement.instrument.smua.ROF","Set bit indicates that an overflow reading has been detected.","Bit B7 decimal value: 128","B8","status.measurement.instrument.smua.BUFFER_AVAILABLE","status.measurement.instrument.smua.BAV","Set bit indicates that there is at least one reading stored in either or both dedicated reading buffers.","Bit B8 decimal value: 256","B9 to B15","Not used","* This bit is updated only when a measurement is made or smua.source.compliance is invoked.","As an example, to set bit B0 of the measurement event SMU A summary enable register, set status.measurement.instrument.smua.enable = status.measurement.instrument.smua.VLMT.","In addition to the above constants, measurementRegister can be set to the decimal equivalent of the bit to set. To set more than one bit of the register, set measurementRegister to the sum of their decimal weights. For example, to set bits B1 and B8, set measurementRegister to 258 (which is the sum of 2 + 256). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","status.measurement.instrument.smua.enable = status.measurement.instrument.smua.VLMT","Uses a constant to set the VLMT bit of the measurement event SMU A summary enable register.","Example 2","status.measurement.instrument.smua.enable = 1","Uses the decimal value to set the VLMT bit of the measurement event SMU A summary enable register.","Also see","Measurement event registers","smua.pulser.protect.tripped","status.measurement.instrument.smua.*","92690.htm"); +Page[378]=new Array("This attribute contains the registers of the measurement event protection summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","measurementRegister = status.measurement.protection.condition","measurementRegister = status.measurement.protection.enable","measurementRegister = status.measurement.protection.event","measurementRegister = status.measurement.protection.ntr","measurementRegister = status.measurement.protection.ptr","status.measurement.protection.enable = measurementRegister","status.measurement.protection.ntr = measurementRegister","status.measurement.protection.ptr = measurementRegister","measurementRegister","The status of the measurement event protection summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the measurement event protection summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table. ","Bit","Value","B0","Not used","B1","status.measurement.protection.SMUA","Set bit indicates one of the pulser protection circuits have tripped.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","In addition to the above constants, measurementRegister can be set to the decimal value of the bit to set.","Example 1","status.measurement.protection.enable = status.measurement.protection.SMUA","Uses the constant to set bit 1, the SMU A bit of the measurement event protection summary enable register.","Example 2","status.measurement.protection.enable = 2","Uses the decimal value to set bit 1, the SMU A bit of the measurement event protection summary enable register.","Also see","Measurement event registers","status.measurement.protection.*","92743.htm"); +Page[379]=new Array("This attribute contains the measurement event reading overflow summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","measurementRegister = status.measurement.reading_overflow.condition","measurementRegister = status.measurement.reading_overflow.enable","measurementRegister = status.measurement.reading_overflow.event","measurementRegister = status.measurement.reading_overflow.ntr","measurementRegister = status.measurement.reading_overflow.ptr","status.measurement.reading_overflow.enable = measurementRegister","status.measurement.reading_overflow.ntr = measurementRegister","status.measurement.reading_overflow.ptr = measurementRegister","measurementRegister","The status of the measurement reading overflow summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the measurement event reading overflow summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, assume the value 2 is returned for the enable register. The binary equivalent is 0000 0000 0000 0010. This value indicates that bit B1 (SMUA) is set.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.measurement.reading_overflow.SMUA","Set bit indicates that an overflow reading has been detected for SMU A.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","In addition to the above constants, measurementRegister can be set to the decimal value of the bit to set.","Example 1","status.measurement.reading_overflow.enable = status.measurement.reading_overflow.SMUA","Uses the constant to set bit B1 of the measurement reading overflow summary enable register.","Example 2","status.measurement.reading_overflow.enable = 2","Uses the decimal value to set bit B1 of the measurement reading overflow summary enable register.","Also see","Measurement event registers","status.measurement.reading_overflow.*","93010.htm"); +Page[380]=new Array("This attribute contains the measurement event voltage limit summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set) ","Usage","measurementRegister = status.measurement.voltage_limit.condition","measurementRegister = status.measurement.voltage_limit.enable","measurementRegister = status.measurement.voltage_limit.event","measurementRegister = status.measurement.voltage_limit.ntr","measurementRegister = status.measurement.voltage_limit.ptr","status.measurement.voltage_limit.enable = measurementRegister","status.measurement.voltage_limit.ntr = measurementRegister","status.measurement.voltage_limit.ptr = measurementRegister","measurementRegister","The status of the measurement voltage limit summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other decimal values indicate various bit settings ","Details","These attributes read or write to the measurement event voltage limit summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.measurement.voltage_limit.SMUA","Set bit indicates the enabled VLMT bit for the SMU A measurement register is set.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","In addition to the above constants, measurementRegister can be set to the decimal value of the bit to set.","Example 1","status.measurement.voltage_limit.enable = status.measurement.voltage_limit.SMUA","Uses the constant to set the SMUA bit, B1, of the measurement event voltage limit summary enable register.","Example 2","status.measurement.voltage_limit.enable = 2","Uses the decimal value to set the SMUA bit, B1, of the measurement event voltage limit summary enable register.","Also see","Measurement event registers","status.measurement.voltage_limit.*","93012.htm"); +Page[381]=new Array("This attribute stores the system node enable register. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Status reset","Not saved","0","Usage","nodeEnableRegister = status.node_enable","status.node_enable = nodeEnableRegister","nodeEnableRegister","The status of the system node enable register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","This attribute is used to read or write to the system node enable register. Reading the system node enable register returns a value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">","*","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","Assigning a value to this attribute enables one or more status events. When an enabled status event occurs, a summary bit is set in the appropriate system summary register. The register and bit that is set depends on the TSP-Link node number assigned to this instrument.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","status.MEASUREMENT_SUMMARY_BIT","status.MSB","Set summary bit indicates that an enabled measurement event has occurred.","Bit B0 decimal value: 1","B1","Not used","B2","status.ERROR_AVAILABLE","status.EAV","Set summary bit indicates that an error or status message is present in the error queue.","Bit B2 decimal value: 4","B3","status.QUESTIONABLE_SUMMARY_BIT","status.QSB","Set summary bit indicates that an enabled questionable event has occurred.","Bit B3 decimal value: 8","B4","status.MESSAGE_AVAILABLE","status.MAV","Set summary bit indicates that a response message is present in the output queue.","Bit B4 decimal value: 16","B5","status.EVENT_SUMMARY_BIT","status.ESB","Set summary bit indicates that an enabled standard event has occurred.","Bit B5 decimal value: 32","B6","status.MASTER_SUMMARY_STATUS","status.MSS","Set bit indicates that an enabled Master Summary Status (MSS) bit of the Status Byte Register is set.","Bit B6 decimal value: 64","B7","status.OPERATION_SUMMARY_BIT","status.OSB","Set summary bit indicates that an enabled operation event has occurred.","Bit B7 decimal value: 128","As an example, to set the B0 bit of the system node enable register, set status.node_enable = status.MSB.","In addition to the above values, nodeEnableRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set nodeEnableRegister to the sum of their decimal weights. For example, to set bits B0 and B7, set nodeEnableRegister to 129 (1 + 128).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Example 1","nodeEnableRegister = status.MSB + status.OSB","status.node_enable = nodeEnableRegister","Use constants to set the MSB and OSB bits of the system node enable register.","Example 2","-- decimal 129 = binary 10000001","nodeEnableRegister = 129","status.node_enable = nodeEnableRegister","Sets the MSB and OSB bits of the system node enable register using a decimal value.","Also see","status.condition","status.system.*","Status byte and service request (SRQ)","status.node_enable","15830.htm"); +Page[382]=new Array("This attribute stores the status node event register.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not saved","0","Usage","nodeEventRegister = status.node_event","nodeEventRegister","The status of the node event register; a zero (0) indicates no bits set; other values indicate various bit settings","Details","This attribute is used to read the status node event register, which is returned as a numeric value (reading this register returns a value). The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">","*","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","The returned value can indicate one or more status events occurred.","Bit","Value and description","B0","status.MEASUREMENT_SUMMARY_BIT","status.MSB","Set summary bit indicates that an enabled measurement event has occurred.","Bit B0 decimal value: 1","B1","Not used","B2","status.ERROR_AVAILABLE","status.EAV","Set summary bit indicates that an error or status message is present in the error queue.","Bit B2 decimal value: 4","B3","status.QUESTIONABLE_SUMMARY_BIT","status.QSB","Set summary bit indicates that an enabled questionable event has occurred.","Bit B3 decimal value: 8","B4","status.MESSAGE_AVAILABLE","status.MAV","Set summary bit indicates that a response message is present in the output queue.","Bit B4 decimal value: 16","B5","status.EVENT_SUMMARY_BIT","status.ESB","Set summary bit indicates that an enabled standard event has occurred.","Bit B5 decimal value: 32","B6","status.MASTER_SUMMARY_STATUS","status.MSS","Set bit indicates that an enabled Master Summary Status (MSS) bit of the Status Byte register is set.","Bit B6 decimal value: 64","B7","status.OPERATION_SUMMARY_BIT","status.OSB","Set summary bit indicates that an enabled operation event has occurred.","Bit B7 decimal value: 128","In addition to the above constants, nodeEventRegister can be set to the decimal equivalent of the bits set. When more than one bit of the register is set, nodeEventRegister contains the sum of their decimal weights. For example, if 129 is returned, bits B0 and B7 are set (1 + 128).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Example","nodeEventRegister = status.node_event","print(nodeEventRegister)","Reads the status node event register.","Sample output:","1.29000e+02","Converting this output (129) to its binary equivalent yields 1000 0001. Therefore, this output indicates that the set bits of the status byte condition register are presently B0 (MSB) and B7 (OSB).","Also see","Status byte and service request (SRQ)","status.condition","status.system.*","status.node_event","15831.htm"); +Page[383]=new Array("These attributes manage the operation status register set of the status model.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","31,769 (All bits set)","Usage","operationRegister = status.operation.condition","operationRegister = status.operation.enable","operationRegister = status.operation.event","operationRegister = status.operation.ntr","operationRegister = status.operation.ptr","status.operation.enable = operationRegister","status.operation.ntr = operationRegister","status.operation.ptr = operationRegister","operationRegister","The status of the operation status register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes read or write the operation status registers.","Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 2.04800e+04 (which is 20,480) is read as the value of the condition register, the binary equivalent is 0101 0000 0000 0000. This value indicates that bit B14 (PROGRAM_RUNNING) and bit B12 (USER) are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","1","0","1","0","0","0","0","0","0","0","0","0","0","0","0","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","status.operation.CALIBRATING","status.operation.CAL","Set bit indicates that the summary bit of the status.operation.calibrating register has been set.","Bit B0 decimal value: 1","B1 to B2","Not used","B3","status.operation.SWEEPING","status.operation.SWE","Set bit indicates that the summary bit from the status.operation.sweeping register is set.","Bit B3 decimal value: 8","B4","status.operation.MEASURING","status.operation.MEAS","Set bit indicates that the summary bit of the status.operation.measuring register is set.","Bit B4 decimal value: 16","B5 to B9","Not used","B10","status.operation.TRIGGER_OVERRUN","status.operation.TRGOVR","Set bit indicates that the summary bit from the status.operation.trigger_overrun register is set.","Bit B10 decimal value: 1,024","B11","status.operation.REMOTE_SUMMARY","status.operation.REM","Set bit indicates that the summary bit of the status.operation.remote register is set. ","Bit B11 decimal value: 2,048","B12","status.operation.USER","Set bit indicates that the summary bit from the status.operation.user register is set.","Bit B12 decimal value: 4,096","B13","status.operation.INSTRUMENT_SUMMARY","status.operation.INST","Set bit indicates that the summary bit from the status.operation.instrument register is set.","Bit B13 decimal value: 8,192","B14","status.operation.PROGRAM_RUNNING","status.operation.PROG","Set bit indicates that a command or program is running.","Bit B14 decimal value: 16,384","B15","Not used","As an example, to set bit B12 of the operation status enable register, set status.operation.enable = status.operation.USER.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B12 and B14, set operationRegister to 20,480 (which is the sum of 4,096 + 16,384). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","operationRegister = status.operation.USER + status.operation.PROG","status.operation.enable = operationRegister","Uses constants to set the USER and PROG bits of the operation status enable register.","Example 2","-- decimal 20480 = binary 0101 0000 0000 0000","operationRegister = 20480","status.operation.enable = operationRegister","Uses a decimal value to set the USER and PROG bits of the operation status enable register.","Also see","Operation Status Registers","status.operation.*","15833.htm"); +Page[384]=new Array("This attribute contains the operation status calibration summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","operationRegister = status.operation.calibrating.condition","operationRegister = status.operation.calibrating.enable","operationRegister = status.operation.calibrating.event","operationRegister = status.operation.calibrating.ntr","operationRegister = status.operation.calibrating.ptr","status.operation.calibrating.enable = operationRegister","status.operation.calibrating.ntr = operationRegister","status.operation.calibrating.ptr = operationRegister ","operationRegister","The status of the operation calibrating event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings ","Details","These attributes are used to read or write to the operation status calibration summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table. ","Bit","Value and description","B0","Not used","B1","status.operation.calibrating.SMUA","Set bit indicates that SMU A is unlocked for calibration.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","Example 1","status.operation.calibrating.enable = status.operation.calibrating.SMUA","Sets the SMUA bit, B1, of the operation status calibration summary enable register using a constant.","Example 2","status.operation.calibrating.enable = 2","Sets the SMUA bit, B1, of the operation status calibration summary enable register using a decimal value.","Also see","Operation Status Registers","status.operation.*","status.operation.calibrating.*","93014.htm"); +Page[385]=new Array("This attribute contains the operation status instrument summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","31,746 (All bits set)","Usage","operationRegister = status.operation.instrument.condition","operationRegister = status.operation.instrument.enable","operationRegister = status.operation.instrument.event","operationRegister = status.operation.instrument.ntr","operationRegister = status.operation.instrument.ptr","status.operation.instrument.enable = operationRegister","status.operation.instrument.ntr = operationRegister","status.operation.instrument.ptr = operationRegister ","operationRegister","The status of the operation event register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status instrument summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1,026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","1","0","0","0","0","0","0","0","0","1","0","* Least significant bit
** Most significant bit
","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.operation.instrument.SMUA","Set bit indicates one or more enabled bits for the operation status SMU A summary register is set.","Bit B1 decimal value: 2","B2 to B9","Not used","B10","status.operation.instrument.TRIGGER_BLENDER","status.operation.instrument.TRGBLND","Set bit indicates one or more enabled bits for the operation status trigger blender summary register is set.","Bit B10 decimal value: 1,024.","B11","status.operation.instrument.TRIGGER_TIMER","status.operation.instrument.TRGTMR","Set bit indicates one or more enabled bits for the operation status trigger timer summary register is set.","Bit B11 decimal value: 2,048","B12","status.operation.instrument.DIGITAL_IO","status.operation.instrument.DIGIO","Set bit indicates one or more enabled bits for the operation status digital I/O summary register is set.","Bit B12 decimal value: 4,096","B13","status.operation.instrument.TSPLINK","Set bit indicates one or more enabled bits for the operation status TSP-Link summary register is set.","Bit B13 decimal value: 8,192","B14","status.operation.instrument.LAN","Set bit indicates one or more enabled bits for the operation status LAN summary register is set.","Bit B14 decimal value: 16,384","B15","Not used","As an example, to set bit B1 of the operation status instrument summary enable register, set status.operation.instrument.enable = status.operation.instrument.SMUA.","In addition to the above constants, operationRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1,024). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","operationRegister = status.operation.instrument.SMUA +"," status.operation.instrument.TRGBLND","status.operation.instrument.enable = operationRegister","Use constants to set bit B1 and bit B10 of the operation status instrument summary enable register. ","Example 2","-- 1026 = binary 0000 0100 0000 0010","operationRegister = 1026","status.operation.instrument.enable = operationRegister","Uses a decimal value to set bit B1 and bit B10 of the operation status instrument summary enable register.","Also see","Operation Status Registers","status.operation.*","Condition register sets of:","• status.operation.instrument.digio.*","• status.operation.instrument.lan.*","• status.operation.instrument.trigger_blender.*","• status.operation.instrument.trigger_timer.*","• status.operation.instrument.tsplink.*","status.operation.instrument.*","93016.htm"); +Page[386]=new Array("This attribute contains the operation status digital I/O summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","1024 (All bits set)","Usage","operationRegister = status.operation.instrument.digio.condition","operationRegister = status.operation.instrument.digio.enable","operationRegister = status.operation.instrument.digio.event","operationRegister = status.operation.instrument.digio.ntr","operationRegister = status.operation.instrument.digio.ptr","status.operation.instrument.digio.enable = operationRegister","status.operation.instrument.digio.ntr = operationRegister","status.operation.instrument.digio.ptr = operationRegister ","operationRegister","The status of the operation status digital I/O summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024","Details","These attributes are used to read or write to the operation status digital I/O summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0 to B9","Not used","B10","status.operation.instrument.digio.TRIGGER_OVERRUN","status.operation.instrument.digio.TRGOVR","Set bit indicates an enabled bit in the Operation Status Digital I/O Overrun Register is set.","Bit B10 decimal value: 1,024","Binary value: 0100 0000 0010","B11 to B15","Not used","In addition to the above constant, operationRegister can be set to the decimal value of the bit to set.","Example 1","status.operation.instrument.digio.enable = status.operation.instrument.digio.TRGOVR","Uses a constant to set the TRGOVR bit of the operation status digital I/O summary enable register.","Example 2","status.operation.instrument.digio.enable = 1024","Uses the decimal value to set the TRGOVR bit of the operation status digital I/O summary enable register.","Also see","Operation Status Registers","status.operation.instrument.digio.trigger_overrun.*","status.operation.instrument.digio.*","15836.htm"); +Page[387]=new Array("This attribute contains the operation status digital I/O overrun register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","32,766 (All bits set)","Usage","operationRegister = status.operation.instrument.digio.trigger_overrun.condition","operationRegister = status.operation.instrument.digio.trigger_overrun.enable","operationRegister = status.operation.instrument.digio.trigger_overrun.event","operationRegister = status.operation.instrument.digio.trigger_overrun.ntr","operationRegister = status.operation.instrument.digio.trigger_overrun.ptr","status.operation.instrument.digio.trigger_overrun.enable = operationRegister","status.operation.instrument.digio.trigger_overrun.ntr = operationRegister","status.operation.instrument.digio.trigger_overrun.ptr = operationRegister","operationRegister","The status of the operation status digio I/O overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status digital I/O overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","1","0","0","0","0","0","0","0","0","1","0","* Least significant bit
** Most significant bit
","A set bit indicates that the specified digital I/O line generated an action overrun when it was triggered to generate an output trigger.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","Not used","Not applicable","B1","status.operation.instrument.digio.trigger_overrun.LINE1","2","B2","status.operation.instrument.digio.trigger_overrun.LINE2","4","B3","status.operation.instrument.digio.trigger_overrun.LINE3","8","B4","status.operation.instrument.digio.trigger_overrun.LINE4","16","B5","status.operation.instrument.digio.trigger_overrun.LINE5","32","B6","status.operation.instrument.digio.trigger_overrun.LINE6","64","B7","status.operation.instrument.digio.trigger_overrun.LINE7","128","B8","status.operation.instrument.digio.trigger_overrun.LINE8","256","B9","status.operation.instrument.digio.trigger_overrun.LINE9","512","B10","status.operation.instrument.digio.trigger_overrun.LINE10","1,024","B11","status.operation.instrument.digio.trigger_overrun.LINE11","2,048","B12","status.operation.instrument.digio.trigger_overrun.LINE12","4,096","B13","status.operation.instrument.digio.trigger_overrun.LINE13","8,192","B14","status.operation.instrument.digio.trigger_overrun.LINE14","16,384","B15","Not used","Not applicable","As an example, to set bit B1 of the operation status digital I/O overrun enable register, set status.operation.instrument.digio.trigger_overrun.enable = status.operation.instrument.digio.trigger_overrun.LINE1.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1,024). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","operationRegister = status.operation.instrument.digio.trigger_overrun.LINE1 +"," status.operation.instrument.digio.trigger_overrun.LINE10","status.operation.instrument.digio.trigger_overrun.enable = operationRegister","Uses constants to set bit B1 and bit B10 of the operation status digital I/O overrun enable register.","Example 2","operationRegister = 1026","status.operation.instrument.digio.trigger_overrun.enable = operationRegister","Uses the decimal value to set bit B1 and bit B10 of the operation status digital I/O overrun enable register.","Also see","Operation Status Registers","status.operation.instrument.digio.*","status.operation.instrument.digio.trigger_overrun.*","15837.htm"); +Page[388]=new Array("This attribute contains the operation status LAN summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","1027 (All bits set)","Usage","operationRegister = status.operation.instrument.lan.condition","operationRegister = status.operation.instrument.lan.enable","operationRegister = status.operation.instrument.lan.event","operationRegister = status.operation.instrument.lan.ntr","operationRegister = status.operation.instrument.lan.ptr","status.operation.instrument.lan.enable = operationRegister","status.operation.instrument.lan.ntr = operationRegister","status.operation.instrument.lan.ptr = operationRegister ","operationRegister","The status of the operation status LAN summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status LAN summary registers. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","1","0","0","0","0","0","0","0","0","1","0","* Least significant bit
** Most significant bit
","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","status.operation.instrument.lan.CONNECTION","status.operation.instrument.lan.CON","Set bit indicates that the LAN cable is connected and a link has been detected.","Bit B0 decimal value: 1","B1","status.operation.instrument.lan.CONFIGURING","status.operation.instrument.lan.CONF","Set bit indicates the LAN is performing its configuration sequence.","Bit B1 decimal value: 2","B2 to B9","Not used","B10","status.operation.instrument.lan.TRIGGER_OVERRUN","status.operation.instrument.lan.TRGOVR","Set bit indicates one or more enabled bits for the operation status LAN trigger overrun register is set.","Bit B10 decimal value: 1,024","B11 to B15","Not used","As an example, to set bit B0 of the operation status LAN summary enable register, set status.operation.instrument.lan.enable = status.operation.instrument.lan.CON.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1024). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","operationRegister = status.operation.instrument.lan.CONF +"," status.operation.instrument.lan.TRGOVR","status.operation.instrument.lan.enable = operationRegister","Use constants to set bit B1 and bit B10 of the operation status LAN summary enable register.","Example 2","operationRegister = 1026","status.operation.instrument.lan.enable = operationRegister","Use the decimal value to set bit B1 and bit B10 of the operation status LAN summary enable register.","Also see","Operation Status Registers","status.operation.instrument.lan.trigger_overrun.*","status.operation.instrument.lan.*","15838.htm"); +Page[389]=new Array("This attribute contains the operation status LAN trigger overrun register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","510 (All bits set)","Usage","operationRegister = status.operation.instrument.lan.trigger_overrun.condition","operationRegister = status.operation.instrument.lan.trigger_overrun.enable","operationRegister = status.operation.instrument.lan.trigger_overrun.event","operationRegister = status.operation.instrument.lan.trigger_overrun.ntr","operationRegister = status.operation.instrument.lan.trigger_overrun.ptr","status.operation.instrument.lan.trigger_overrun.enable = operationRegister","status.operation.instrument.lan.trigger_overrun.ntr = operationRegister","status.operation.instrument.lan.trigger_overrun.ptr = operationRegister ","operationRegister","The status of the operation status LAN trigger overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status LAN trigger overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 2.58000e+02 (which is 258) is read as the value of the condition register, the binary equivalent is 0000 0001 0000 0010. This value indicates that bit B1 and bit B8 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","1","0","0","0","0","0","0","1","0","* Least significant bit
** Most significant bit
","A set bit indicates that the specified LAN trigger generated an action overrun when triggered to generate a trigger packet.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","Not used","Not applicable","B1","status.operation.instrument.lan.trigger_overrun.LAN1","2","B2","status.operation.instrument.lan.trigger_overrun.LAN2","4","B3","status.operation.instrument.lan.trigger_overrun.LAN3","8","B4","status.operation.instrument.lan.trigger_overrun.LAN4","16","B5","status.operation.instrument.lan.trigger_overrun.LAN5","32","B6","status.operation.instrument.lan.trigger_overrun.LAN6","64","B7","status.operation.instrument.lan.trigger_overrun.LAN7","128","B8","status.operation.instrument.lan.trigger_overrun.LAN8","256","B9 to B15","Not used","Not applicable","As an example, to set bit B1 of the operation status LAN trigger overrun enable register, set status.operation.instrument.lan.trigger_overrun.enable = status.operation.instrument.lan.trigger_overrun.LAN1.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B8, set operationRegister to 258 (which is the sum of 2 + 256).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","operationRegister = status.operation.instrument.lan.trigger_overrun.LAN1 +"," status.operation.instrument.lan.trigger_overrun.LAN8","status.operation.instrument.lan.trigger_overrun.enable = operationRegister","Use constants to set bit B1 and bit B8 of the operation status LAN trigger overrun enable register.","Example 2","operationRegister = 258","status.operation.instrument.lan.trigger_overrun.enable = operationRegister","Use the decimal value to set bit B1 and bit B8 of the operation status LAN trigger overrun enable register.","Also see","Operation Status Registers","status.operation.instrument.lan.*","status.operation.instrument.lan.trigger_overrun.*","15839.htm"); +Page[390]=new Array("This attribute contains the operation status SMU summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","1049 (All bits set)","Usage","operationRegister = status.operation.instrument.smua.condition","operationRegister = status.operation.instrument.smua.enable","operationRegister = status.operation.instrument.smua.event","operationRegister = status.operation.instrument.smua.ntr","operationRegister = status.operation.instrument.smua.ptr","status.operation.instrument.smua.enable = operationRegister","status.operation.instrument.smua.ntr = operationRegister","status.operation.instrument.smua.ptr = operationRegister ","operationRegister","The status of the operation status SMU summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status SMU summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02500e+02 (which is 1,025) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B0 and bit B10 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","1","0","0","0","0","0","0","0","0","1","0","* Least significant bit
** Most significant bit
","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","status.operation.instrument.smua.CALIBRATING","status.operation.instrument.smua.CAL","Set bit indicates that smua is unlocked for calibration.","Bit B0 decimal value: 1","B1 to B2","Not used","B3","status.operation.instrument.smua.SWEEPING","status.operation.instrument.smua.SWE","Set bit indicates that smua is sweeping.","Bit B3 decimal value: 8","B4","status.operation.instrument.smua.MEASURING","status.operation.instrument.smua.MEAS","Bit is set when making an overlapped measurement, but it will not set when taking a normal synchronous measurement.","Bit B4 decimal value: 16","B5 to B9","Not used","B10","status.operation.instrument.smua.TRIGGER_OVERRUN","status.operation.instrument.smua.TRGOVR","Set bit indicates an enabled bit has been set in the operation status smua trigger overrun event register.","Bit B10 decimal value: 1,024","B11 to B15","Not used","As an example, to set bit B0 of the operation status SMU A summary enable register, set status.operation.instrument.smua.enable = status.operation.instrument.smua.CAL.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B0 and B10, set operationRegister to 1,025 (which is the sum of 1 + 1,024). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","status.operation.instrument.smua.enable = status.operation.instrument.smua.MEAS","Use a constant to set bit B4t of the operation status SMU A summary enable register.","Example 2","status.operation.instrument.smua.enable = 1025","Use the decimal value to set bits B0 and B10 of the operation status SMU A summary enable register.","Also see","Operation Status Registers","status.operation.instrument.smua.trigger_overrrun.*","status.operation.instrument.smua.*","15840.htm"); +Page[391]=new Array("This attribute contains the operation status SMU trigger overrun register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","30 (All bits set)","Usage","operationRegister = status.operation.instrument.smua.trigger_overrun.condition","operationRegister = status.operation.instrument.smua.trigger_overrun.enable","operationRegister = status.operation.instrument.smua.trigger_overrun.event","operationRegister = status.operation.instrument.smua.trigger_overrun.ntr","operationRegister = status.operation.instrument.smua.trigger_overrun.ptr","status.operation.instrument.smua.trigger_overrun.enable = operationRegister","status.operation.instrument.smua.trigger_overrun.ntr = operationRegister","status.operation.instrument.smua.trigger_overrun.ptr = operationRegister ","operationRegister","The status of the operation status SMU trigger overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status SMU trigger overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 18 is read as the value of the condition register, the binary equivalent is 0000 0000 0001 0010. This value indicates that bit B1 and bit B4 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","0","0","0","1","0","0","1","0","* Least significant bit
** Most significant bit
","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.operation.instrument.smua.trigger_overrun.ARM","Set bit indicates that the arm event detector of the SMU was already in the detected state when a trigger was received.","Bit B1 decimal value: 2","B2","status.operation.instrument.smua.trigger_overrun.SRC","Set bit indicates that the source event detector of the SMU was already in the detected state when a trigger was received.","Bit B2 decimal value: 4","B3","status.operation.instrument.smua.trigger_overrun.MEAS","Set bit indicates that the measurement event detector of the SMU was already in the detected state when a trigger was received.","Bit B3 decimal value: 8","B4","status.operation.instrument.smua.trigger_overrun.ENDP","Set bit indicates that the end pulse event detector of the SMU was already in the detected state when a trigger was received.","Bit B4 decimal value: 16","B5 to B15","Not used","As an example, to set bit B1 of the operation status SMU A trigger overrun enable register, set status.operation.instrument.smua.trigger_overrun.enable = 
status.operation.instrument.smua.trigger_overrun.ARM.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set operationRegister to 18 (which is the sum of 2 + 16). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","status.operation.instrument.smua.trigger_overrun.enable ="," status.operation.instrument.smua.trigger_overrun.ARM","Uses a constant to sets the ARM bit of the operation status SMU A trigger overrun enable register.","Example 2","status.operation.instrument.smua.trigger_overrun.enable = 18","Uses the decimal value to set bits B1 and B4 of the operation status SMU A trigger overrun enable register.","Also see","Operation Status Registers","status.operation.instrument.smua.*","status.operation.instrument.smua.trigger_overrrun.*","15841.htm"); +Page[392]=new Array("This attribute contains the operation status trigger blender summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","1024 (All bits set)","Usage","operationRegister = status.operation.instrument.trigger_blender.condition","operationRegister = status.operation.instrument.trigger_blender.enable","operationRegister = status.operation.instrument.trigger_blender.event","operationRegister = status.operation.instrument.trigger_blender.ntr","operationRegister = status.operation.instrument.trigger_blender.ptr","status.operation.instrument.trigger_blender.enable = operationRegister","status.operation.instrument.trigger_blender.ntr = operationRegister","status.operation.instrument.trigger_blender.ptr = operationRegister","operationRegister","The status of the operation status trigger blender summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024","Details","These attributes are used to read or write to the operation status trigger blender summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0 to B9","Not used","B10","status.operation.instrument.trigger_blender.TRIGGER_OVERRUN","status.operation.instrument.trigger_blender.TRGOVR","Set bit indicates one or more enabled bits for operation status trigger blender overrun register is set.","Bit B10 decimal value: 1,024","Binary value:
0100 0000 0000","B11 to B15","Not used","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. For example, to set bit B10, set operationRegister to 1024.","Example","status.operation.instrument.trigger_blender.enable = 1024","Uses a decimal value to set the TRGOVR bit of the operation status trigger blender summary enable.","Also see","Operation Status Registers","status.operation.instrument.trigger_blender.trigger_overrun.*","status.operation.instrument.trigger_blender.*","15842.htm"); +Page[393]=new Array("This attribute contains the operation status trigger blender overrun register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","126 (All bits set)","Usage","operationRegister = "," status.operation.instrument.trigger_blender.trigger_overrun.condition","operationRegister ="," status.operation.instrument.trigger_blender.trigger_overrun.enable","operationRegister ="," status.operation.instrument.trigger_blender.trigger_overrun.event","operationRegister ="," status.operation.instrument.trigger_blender.trigger_overrun.ntr","operationRegister ="," status.operation.instrument.trigger_blender.trigger_overrun.ptr","status.operation.instrument.trigger_blender.trigger_overrun.enable ="," operationRegister","status.operation.instrument.trigger_blender.trigger_overrun.ntr ="," operationRegister","status.operation.instrument.trigger_blender.trigger_overrun.ptr ="," operationRegister ","operationRegister","The status of the operation status trigger blender overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status trigger blender overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 18 is read as the value of the condition register, the binary equivalent is 0000 0000 0001 0010. This value indicates that bit B1 and bit B4 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","0","0","0","1","0","0","1","0","* Least significant bit
** Most significant bit
","A set bit value indicates that the specified trigger blender generated an action overrun.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","Not used","Not applicable","B1","status.operation.instrument.trigger_blender.trigger_overrun.BLND1","2","B2","status.operation.instrument.trigger_blender.trigger_overrun.BLND2","4","B3","status.operation.instrument.trigger_blender.trigger_overrun.BLND3","8","B4","status.operation.instrument.trigger_blender.trigger_overrun.BLND4","16","B5","status.operation.instrument.trigger_blender.trigger_overrun.BLND5","32","B6","status.operation.instrument.trigger_blender.trigger_overrun.BLND6"," 64","B7 to B15","Not used","Not applicable","As an example, to set bit B1 of the operation status trigger blender overrun enable register, set status.operation.instrument.trigger_blender.trigger_overrun.enable = status.operation.instrument.trigger_blender.trigger_overrun.BLND1.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set operationRegister to 18 (which is the sum of 2 + 16).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example","status.operation.instrument.trigger_blender.trigger_overrun.enable"," = status.operation.instrument.trigger_blender.trigger_overrun.BLND1","Uses the constant to set the bit for blender 1 of the operation status trigger blender overrun enable register.","Example","status.operation.instrument.trigger_blender.trigger_overrun.enable = 18","Uses the decimal value to set the bits for blenders 1 and 4 of the operation status trigger blender overrun enable register.","Also see","Operation Status Registers","status.operation.instrument.trigger_blender.*","status.operation.instrument.trigger_blender.trigger_overrun.*","29234.htm"); +Page[394]=new Array("This attribute contains the operation status trigger timer summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","1024 (All bits set)","Usage","operationRegister = status.operation.instrument.trigger_timer.condition","operationRegister = status.operation.instrument.trigger_timer.enable","operationRegister = status.operation.instrument.trigger_timer.event","operationRegister = status.operation.instrument.trigger_timer.ntr","operationRegister = status.operation.instrument.trigger_timer.ptr","status.operation.instrument.trigger_timer.enable = operationRegister","status.operation.instrument.trigger_timer.ntr = operationRegister","status.operation.instrument.trigger_timer.ptr = operationRegister ","operationRegister","The status of the operation status trigger timer summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024","Details","These attributes are used to read or write to the operation status trigger timer summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0 to B9","Not used","B10","status.operation.instrument.trigger_timer.TRIGGER_OVERRUN","status.operation.instrument.trigger_timer.TRGOVR","Set bit indicates one or more enabled bits for the operation status trigger timer overrun register is set.","Bit B10 decimal value: 1,024","Binary value:
0100 0000 0000","B11 to B15","Not used","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. For example, to set bit B10, set operationRegister to 1024.","Example","status.operation.instrument.trigger_timer.enable = 1024","Uses the decimal value to set the TRGOVR bit of the operation status trigger timer summary enable register.","Also see","Operation Status Registers","status.operation.instrument.trigger_timer.trigger_overrun.*","status.operation.instrument.trigger_timer.*","15844.htm"); +Page[395]=new Array("This attribute contains the operation status trigger timer overrun register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","510 (All bits set)","Usage","operationRegister = "," status.operation.instrument.trigger_timer.trigger_overrun.condition","operationRegister = "," status.operation.instrument.trigger_timer.trigger_overrun.enable","operationRegister = "," status.operation.instrument.trigger_timer.trigger_overrun.event","operationRegister = "," status.operation.instrument.trigger_timer.trigger_overrun.ntr","operationRegister = "," status.operation.instrument.trigger_timer.trigger_overrun.ptr","status.operation.instrument.trigger_timer.trigger_overrun.enable = "," operationRegister","status.operation.instrument.trigger_timer.trigger_overrun.ntr = "," operationRegister","status.operation.instrument.trigger_timer.trigger_overrun.ptr = "," operationRegister ","operationRegister","The status of the operation status trigger timer trigger overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status trigger timer overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 18 is read as the value of the condition register, the binary equivalent is 0000 0000 0001 0010. This value indicates that bit B1 and bit B4 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","0","0","0","1","0","0","1","0","* Least significant bit
** Most significant bit","A set bit indicates the specified timer generated an action overrun because it was still processing a delay from a previous trigger when a new trigger was received.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","Not used","Not applicable","B1","status.operation.instrument.trigger_timer.trigger_overrun.TMR1","2","B2","status.operation.instrument.trigger_timer.trigger_overrun.TMR2","4","B3","status.operation.instrument.trigger_timer.trigger_overrun.TMR3","8","B4","status.operation.instrument.trigger_timer.trigger_overrun.TMR4","16","B5","status.operation.instrument.trigger_timer.trigger_overrun.TMR5","32","B6","status.operation.instrument.trigger_timer.trigger_overrun.TMR6","64","B7","status.operation.instrument.trigger_timer.trigger_overrun.TMR7","128","B8","status.operation.instrument.trigger_timer.trigger_overrun.TMR8","256","B9 to B15","Not used","Not applicable","As an example, to set bit B1 of the operation status trigger timer trigger overrun enable register, set status.operation.instrument.trigger_timer.trigger_overrun.enable = status.operation.instrument.trigger_timer.trigger_overrun.TMR1.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set operationRegister to 18 (which is the sum of 2 + 16). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","status.operation.instrument.trigger_timer.trigger_overrun.enable ="," status.operation.instrument.trigger_timer.trigger_overrun.TMR3","Uses a constant to set the timer 3 bit of the operation status trigger timer overrun enable register.","Example 2","status.operation.instrument.trigger_timer.trigger_overrun.enable = 18","Uses a constant to set timer bits B1 and B4 of the operation status trigger timer overrun enable register.","Also see","Operation Status Registers","status.operation.instrument.trigger_timer.*","status.operation.instrument.trigger_timer.trigger_overrun.*","15845.htm"); +Page[396]=new Array("This attribute contains the operation status TSP-Link summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","1024 (All bits set)","Usage","operationRegister = status.operation.instrument.tsplink.condition","operationRegister = status.operation.instrument.tsplink.enable","operationRegister = status.operation.instrument.tsplink.event","operationRegister = status.operation.instrument.tsplink.ntr","operationRegister = status.operation.instrument.tsplink.ptr","status.operation.instrument.tsplink.enable = operationRegister","status.operation.instrument.tsplink.ntr = operationRegister","status.operation.instrument.tsplink.ptr = operationRegister ","operationRegister","The status of the operation status TSP-Link summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only valid value other than 0 is 1024","Details","These attributes are used to read or write to the operation status TSP-Link summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0 to B9","Not used","B10","status.operation.instrument.tsplink.TRIGGER_OVERRUN","status.operation.instrument.tsplink.TRGOVR","Set bit indicates one or more enabled bits for the operation status TSP-Link overrun register is set.","Bit B10 decimal value: 1,024","Binary value:
0100 0000 0000","B11 to B15","Not used","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. For example, to set bit B10, set operationRegister to 1024.","Example","status.operation.instrument.tsplink.enable = 1024","Uses the decimal value to set the trigger overrun bit of the operation status TSP-Link summary enable register.","Also see","Operation Status Registers","status.operation.instrument.tsplink.trigger_overrun.*","status.operation.instrument.tsplink.*","15846.htm"); +Page[397]=new Array("This attribute contains the operation status TSP-Link overrun register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","14 (All bits set)","Usage","operationRegister = "," status.operation.instrument.tsplink.trigger_overrun.condition","operationRegister = status.operation.instrument.tsplink.trigger_overrun.enable","operationRegister = status.operation.instrument.tsplink.trigger_overrun.event","operationRegister = status.operation.instrument.tsplink.trigger_overrun.ntr","operationRegister = status.operation.instrument.tsplink.trigger_overrun.ptr","status.operation.instrument.tsplink.trigger_overrun.enable = operationRegister","status.operation.instrument.tsplink.trigger_overrun.ntr = operationRegister","status.operation.instrument.tsplink.trigger_overrun.ptr = operationRegister ","operationRegister","The status of the operation status TSP-link overrun register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status TSP-link overrun registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 10 is read as the value of the condition register, the binary equivalent is 0000 0000 0000 1010. This value indicates that bit B1 and bit B3 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","0","0","0","0","1","0","1","0","* Least significant bit
** Most significant bit
","A set bit indicates that the specified line generated an action overrun when triggered to generate an output trigger.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","Not used","Not applicable","B1","status.operation.instrument.tsplink.trigger_overrun.LINE1","2","B2","status.operation.instrument.tsplink.trigger_overrun.LINE2","4","B3","status.operation.instrument.tsplink.trigger_overrun.LINE3","8","B4 to B15","Not used","Not applicable","As an example, to set bit B1 of the operation status TSP-Link overrun enable register, set status.operation.instrument.tsplink.trigger_overrun.enable = status.operation.instrument.tsplink.trigger_overrun.LINE1.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B3, set operationRegister to 10 (which is the sum of 2 + 8). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","status.operation.instrument.tsplink.trigger_overrun.enable ="," status.operation.instrument.tsplink.trigger_overrun.LINE1","Uses a constant to set the line 1 bit of the operation status TSP-Link overrun enable register.","Example 2","status.operation.instrument.tsplink.trigger_overrun.enable = 10","Uses the decimal value to set bits for lines 1 and 3 of the operation status TSP-Link overrun enable register.","Also see","Operation Status Registers","status.operation.instrument.trigger_timer.*","status.operation.instrument.tsplink.trigger_overrun.*","15847.htm"); +Page[398]=new Array("This attribute contains the operation status measuring summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","operationRegister = status.operation.measuring.condition","operationRegister = status.operation.measuring.enable","operationRegister = status.operation.measuring.event","operationRegister = status.operation.measuring.ntr","operationRegister = status.operation.measuring.ptr","status.operation.measuring.enable = operationRegister","status.operation.measuring.ntr = operationRegister","status.operation.measuring.ptr = operationRegister ","operationRegister","The status of the operation status measuring summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only other valid value is 2","Details","These attributes are used to read or write to the operation status measuring summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table. ","Bit","Value and description","B0","Not used","B1","status.operation.measuring.SMUA","Bit is set when SMU A is taking an overlapped measurement, but it is not set when taking a normal synchronous measurement.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","In addition to the above constants, operationRegister can be set to the decimal equivalent of the bit to set.","Example 1","status.operation.measuring.enable = status.operation.measuring.SMUA","Uses the constant to set the SMUA bit, B1, of the operation status measuring summary enable register.","Example 2","status.operation.measuring.enable = 2","Uses the decimal value to set the SMUA bit, B1, of the operation status measuring summary enable register.","Also see","Operation Status Registers","status.operation.*","status.operation.measuring.*","93017.htm"); +Page[399]=new Array("This attribute contains the operation status remote summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2050 (All bits set)","Usage","operationRegister = status.operation.remote.condition","operationRegister = status.operation.remote.enable","operationRegister = status.operation.remote.event","operationRegister = status.operation.remote.ntr","operationRegister = status.operation.remote.ptr","status.operation.remote.enable = operationRegister","status.operation.remote.ntr = operationRegister","status.operation.remote.ptr = operationRegister ","operationRegister","The status of the operation status remote summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status remote summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.operation.remote.COMMAND_AVAILABLE","status.operation.remote.CAV","Set bit indicates there is a command available in the execution queue.","Bit B1 decimal value: 2","Binary value: 0000 0000 0000 0010","B2 to B10","Not used","B11","status.operation.remote.PROMPTS_ENABLED","status.operation.remote.PRMPT","Set bit indicates command prompts are enabled.","Bit B11 decimal value: 2,048","Binary value: 0000 0100 0000 0000","B12 to B15","Not used","As an example, to set bit B1 of the operation status remote summary enable register, set status.operation.remote.enable = status.operation.remote.CAV.","In addition to the above constants, operationRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B1 and B11, set operationRegister to 2,050 (which is the sum of 2 + 2,048). ","Example 1","status.operation.remote.enable = status.operation.remote.CAV","Uses a constant to set the CAV bit, B1, of the operation status remote summary enable register.","Example 2","status.operation.remote.enable = 2050","Uses the decimal value to set bits B1 and B11 of the operation status remote summary enable register.","Also see","Operation Status Registers","status.operation.*","status.operation.remote.*","15849.htm"); +Page[400]=new Array("This attribute contains the operation status sweeping summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","operationRegister = status.operation.sweeping.condition","operationRegister = status.operation.sweeping.enable","operationRegister = status.operation.sweeping.event","operationRegister = status.operation.sweeping.ntr","operationRegister = status.operation.sweeping.ptr","status.operation.sweeping.enable = operationRegister","status.operation.sweeping.ntr = operationRegister","status.operation.sweeping.ptr = operationRegister ","operationRegister","The status of the operation status sweeping summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status sweeping summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.operation.sweeping.SMUA","Set bit indicates that SMU A is sweeping.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the operation status sweeping summary enable register, set status.operation.sweeping.enable = status.operation.sweeping.SMUA.","In addition to the above constants, operationRegister can be set to 2, the decimal value of Bit 1.","Example","status.operation.sweeping.enable = status.operation.sweeping.SMUA","Uses a constant to set the SMUA bit of the operation status sweeping summary enable register.","Also see","Operation Status Registers","status.operation.*","status.operation.sweeping.*","93038.htm"); +Page[401]=new Array("This attribute contains the operation status trigger overrun summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","31,746 (All bits set)","Usage","operationRegister = status.operation.trigger_overrun.condition","operationRegister = status.operation.trigger_overrun.enable","operationRegister = status.operation.trigger_overrun.event","operationRegister = status.operation.trigger_overrun.ntr","operationRegister = status.operation.trigger_overrun.ptr","status.operation.trigger_overrun.enable = operationRegister","status.operation.trigger_overrun.ntr = operationRegister","status.operation.trigger_overrun.ptr = operationRegister ","operationRegister","The status of the operation status trigger overrun summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status trigger overrun summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.02600e+03 (which is 1,026) is read as the value of the condition register, the binary equivalent is 0000 0100 0000 0010. This value indicates that bit B1 and bit B10 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","1","0","0","0","0","0","0","0","0","1","0","* Least significant bit
** Most significant bit","The bits in this register summarize events in other registers. A set bit in this summary register indicates that an enabled event in one of the summarized registers is set.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.operation.trigger_overrun.SMUA","Set bit indicates one of the enabled bits in the operation status SMU A trigger overrun event register is set.","Bit B1 decimal value: 2","B2 to B9","Not used","B10","status.operation.trigger_overrun.TRIGGER_BLENDER","status.operation.trigger_overrun.TRGBLND","Set bit indicates one of the enabled bits in the operation status trigger blender overrun event register is set.","Bit B10 decimal value: 1,024","B11","status.operation.trigger_overrun.TRIGGER_TIMER","status.operation.trigger_overrun.TRGTMR","Set bit indicates one of the enabled bits in the operation status trigger timer overrun event register is set.","Bit B11 decimal value: 2,048","B12","status.operation.trigger_overrun.DIGITAL_IO","status.operation.trigger_overrun.DIGIO","Set bit indicates one of the enabled bits in the operation status digital I/O overrun event register is set.","Bit B12 decimal value: 4,096","B13","status.operation.trigger_overrun.TSPLINK","Set bit indicates one of the enabled bits in the operation status TSP-Link overrun event register is set.","Bit B13 decimal value: 8,192","B14","status.operation.trigger_overrun.LAN","Set bit indicates one of the enabled bits in the operation status LAN trigger overrun event register is set.","Bit B14 decimal value: 16,384","B15","Not used","As an example, to set bit B1 of the operation status trigger overrun summary enable register, set status.operation.trigger_overrun.enable = status.operation.trigger_overrun.SMUA.","In addition to the above constants, operationRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal weights. For example, to set bits B1 and B10, set operationRegister to 1,026 (which is the sum of 2 + 1,024).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","operationRegister = status.operation.trigger_overrun.SMUA + status.operation.trigger_overrun.TRGBLND","status.operation.trigger_overrun.enable = operationRegister","Uses constants to set bits B1 and bit B10 of the operation status trigger overrun summary enable register.","Example 2","operationRegister = 1026","status.operation.trigger_overrun.enable = operationRegister","Uses the decimal value to set bits B1 and bit B10 of the operation status trigger overrun summary enable register.","Also see","Operation Status Registers","status.operation.*","status.operation.trigger_overrun.*","93037.htm"); +Page[402]=new Array("These attributes manage the operation status user register set of the status model.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (RW)","Yes","Status reset","Not saved","0",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","32,767 (All bits set)","Usage","operationRegister = status.operation.user.condition","operationRegister = status.operation.user.enable","operationRegister = status.operation.user.event","operationRegister = status.operation.user.ntr","operationRegister = status.operation.user.ptr","status.operation.user.condition = operationRegister","status.operation.user.enable = operationRegister","status.operation.user.ntr = operationRegister","status.operation.user.ptr = operationRegister","operationRegister","The status of the operation status user register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the operation status user registers. Reading a status register returns a value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bits B0 and B7 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","status.operation.user.BIT0","1","B1","status.operation.user.BIT1","2","B2","status.operation.user.BIT2","4","B3","status.operation.user.BIT3","8","B4","status.operation.user.BIT4","16","B5","status.operation.user.BIT5","32","B6","status.operation.user.BIT6","64","B7","status.operation.user.BIT7","128","B8","status.operation.user.BIT8","256","B9","status.operation.user.BIT9","512","B10","status.operation.user.BIT10","1,024","B11","status.operation.user.BIT11","2,048","B12","status.operation.user.BIT12","4,096","B13","status.operation.user.BIT13","8,192","B14","status.operation.user.BIT14","16,384","B15","Not used","Not applicable","As an example, to set bit B0 of the operation status user enable register, set status.operation.user.enable = status.operation.user.BIT0.","In addition to the above constants, operationRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set operationRegister to the sum of their decimal values. For example, to set bits B11 and B14, set operationRegister to 18,432 (which is the sum of 2,048 + 16,384). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","operationRegister = status.operation.user.BIT11 + status.operation.user.BIT14","status.operation.user.enable = operationRegister","Uses constants to set bits B11 and B14 of the operation status user enable register.","Example 2","-- 18432 = binary 0100 1000 0000 0000","operationRegister = 18432","status.operation.enable = operationRegister","Uses the decimal value to set bits B11 and B14 of the operation status user enable register.","Also see","Operation Status Registers","status.operation.*","status.operation.user.*","15852.htm"); +Page[403]=new Array("These attributes manage the questionable status register set of the status model.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","13,056 (All bits set)","Usage","questionableRegister = status.questionable.condition","questionableRegister = status.questionable.enable","questionableRegister = status.questionable.event","questionableRegister = status.questionable.ntr","questionableRegister = status.questionable.ptr","status.questionable.enable = questionableRegister","status.questionable.ntr = questionableRegister","status.questionable.ptr = questionableRegister","questionableRegister","The status of the questionable status register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the questionable status registers. Reading a status register returns a value. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.22880e+04 (which is 12,288) is read as the value of the condition register, the binary equivalent is 0011 0000 0000 0000. This value indicates that bits B12 and B13 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","1","1","0","0","0","0","0","0","0","0","0","0","0","0","* Least significant bit
** Most significant bit
","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0 to B7","Not used","B8","status.questionable.CALIBRATION","status.questionable.CAL","An enabled bit in the questionable status calibration summary event register is set.","Bit B6 decimal value: 256","B9","status.questionable.UNSTABLE_OUTPUT","status.questionable.UO","An enabled bit in the questionable status unstable output summary event register is set.","Bit B9 decimal value: 512","B10","Not used","B11","Not used","B12","status.questionable.OVER_TEMPERATURE","status.questionable.OTEMP","An enabled bit in the questionable status over temperature summary event register is set.","Bit B12 decimal value: 4,096","B13","status.questionable.INSTRUMENT_SUMMARY","status.questionable.INST","An enabled bit in the questionable status instrument summary event register is set.","Bit B13 decimal value: 8,192","B14 to B15","Not used","As an example, to set bit B9 of the questionable status enable register, set status.questionable.enable = status.questionable.UO.","In addition to the above constants, questionableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set questionableRegister to the sum of their decimal values. For example, to set bits B12 and B13, set questionableRegister to 12,288 (which is the sum of 4,096 + 8,192).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","status.questionable.enable = status.questionable.OTEMP","Uses a constant to set the OTEMP bit of the questionable status enable register.","Example 2","status.questionable.enable = 12288","Uses the decimal value to set the B12 and B13 bits of the questionable status enable register.","Also see","Questionable Status Registers","status.questionable.*","92683.htm"); +Page[404]=new Array("This attribute contains the questionable status calibration summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","questionableRegister = status.questionable.calibration.condition","questionableRegister = status.questionable.calibration.enable","questionableRegister = status.questionable.calibration.event","questionableRegister = status.questionable.calibration.ntr","questionableRegister = status.questionable.calibration.ptr","status.questionable.calibration.enable = questionableRegister","status.questionable.calibration.ntr = questionableRegister","status.questionable.calibration.ptr = questionableRegister ","questionableRegister","The status of the questionable status calibration summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the questionable status calibration summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. ","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table. ","Bit","Value and description","B0","Not used","B1","status.questionable.calibration.SMUA","Set bit indicates that the SMU A calibration constants stored in nonvolatile memory were corrupted and could not be loaded when the instrument powered up.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the questionable status calibration summary enable register, set status.questionable.calibration.enable = status.questionable.calibration.SMUA.","In addition to the above constants, questionableRegister can be set to 2, the decimal value of the B1 bit.","Example","status.questionable.calibration.enable = status.questionable.calibration.SMUA","Uses a constant to set the SMUA bit of the questionable status calibration summary enable register.","Also see","Questionable Status Registers","status.questionable.*","status.questionable.calibration.*","93035.htm"); +Page[405]=new Array("This attribute contains the questionable status instrument summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","questionableRegister = status.questionable.instrument.condition","questionableRegister = status.questionable.instrument.enable","questionableRegister = status.questionable.instrument.event","questionableRegister = status.questionable.instrument.ntr","questionableRegister = status.questionable.instrument.ptr","status.questionable.instrument.enable = questionableRegister","status.questionable.instrument.ntr = questionableRegister","status.questionable.instrument.ptr = questionableRegister ","questionableRegister","The status of the questionable status instrument summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only other valid setting is 2","Details","These attributes are used to read or write to the questionable status instrument summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bit is set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.questionable.instrument.SMUA","Set bit indicates one or more enabled bits for the SMU A questionable register are set.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the questionable status instrument summary enable register, set status.questionable.instrument.enable = status.questionable.instrument.SMUA.","In addition to the constant, questionableRegister can be set to the decimal value of the bit.","Example","status.questionable.instrument.enable = status.questionable.instrument.SMUA","Uses a constant to set the SMUA bit of the questionable status instrument summary enable register.","Also see","Questionable Status Registers","status.questionable.*","status.questionable.instrument.*","93000.htm"); +Page[406]=new Array("This attribute contains the questionable status SMU A summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","—","—","—","—",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","4864 (All bits set)","Usage","questionableRegister = status.questionable.instrument.smua.condition","questionableRegister = status.questionable.instrument.smua.enable","questionableRegister = status.questionable.instrument.smua.event","questionableRegister = status.questionable.instrument.smua.ntr","questionableRegister = status.questionable.instrument.smua.ptr","status.questionable.instrument.smua.enable = questionableRegister","status.questionable.instrument.smua.ntr = questionableRegister","status.questionable.instrument.smua.ptr = questionableRegister ","questionableRegister","The status of the questionable status SMU summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the questionable status instrument SMU summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 7.68000e+02 (which is 768) is read as the value of the condition register, the binary equivalent is 0000 0011 0000 0000. This value indicates that bit B8 and bit B9 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","1","1","0","0","0","0","0","0","0","0","* Least significant bit
** Most significant bit
","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0 to B7","Not used","B8","status.questionable.instrument.smua.CALIBRATION","status.questionable.instrument.smua.CAL","Set bit indicates that the calibration constants stored in nonvolatile memory were corrupted and could not be loaded when the instrument powered up.","Bit B8 decimal value: 256","B9","status.questionable.instrument.smua.UNSTABLE_OUTPUT","status.questionable.instrument.smua.UO","Set bit indicates that an unstable output condition was detected.","Bit B9 decimal value: 512","B10 to B11","Not used","B12","status.questionable.instrument.smua.OVER_TEMPERATURE","status.questionable.instrument.smua.OTEMP","Set bit indicates that an over temperature condition was detected.","Bit B12 decimal value: 4,096","B13 to B15","Not used","As an example, to set bit B8 of the questionable status SMU A summary enable register, set status.questionable.instrument.smua.enable = status.questionable.instrument.smua.CAL.","In addition to the above constants, questionableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set questionableRegister to the sum of their decimal values. For example, to set bits B8 and B9, set questionableRegister to 768 (which is the sum of 256 + 512).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example","questionableRegister = status.questionable.instrument.smua.CAL +"," status.questionable.instrument.smua.UO","status.questionable.instrument.smua.enable = questionableRegister","Uses constants to set bits B8 and bit B9 of the questionable status SMU A summary enable register.","Example","questionableRegister = 768","status.questionable.instrument.smua.enable = questionableRegister","Uses the decimal value to set bits B8 and bit B9 of the questionable status SMU A summary enable register.","Also see","Questionable Status Registers","status.operation.*","status.questionable.instrument.smua.*","92697.htm"); +Page[407]=new Array("This attribute contains the questionable status over temperature summary register set. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","questionableRegister = status.questionable.over_temperature.condition","questionableRegister = status.questionable.over_temperature.enable","questionableRegister = status.questionable.over_temperature.event","questionableRegister = status.questionable.over_temperature.ntr","questionableRegister = status.questionable.over_temperature.ptr","status.questionable.over_temperature.enable = questionableRegister","status.questionable.over_temperature.ntr = questionableRegister","status.questionable.over_temperature.ptr = questionableRegister ","operationRegister","The status of the questionable status over temperature summary register; a zero (0) indicates no bits set (also send 0 to clear all bits)","Details","These attributes are used to read or write to the questionable status over temperature summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates if a register bit is set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","B0","Not used","B1","status.questionable.over_temperature.SMUA","Set bit indicates that an over temperature condition was detected on SMU A.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the questionable status over temperature summary enable register, set status.questionable.instrument.enable = status.questionable.instrument.SMUA. You can also set the bit to its decimal value.","Example","status.questionable.over_temperature.enable = status.questionable.over_temperature.SMUA","Uses the constant to set the SMU A over temperature summary enable bit of the questionable status register.","Also see","Questionable Status Registers","status.questionable.*","status.questionable.over_temperature.*","92999.htm"); +Page[408]=new Array("This attribute contains the questionable status unstable output summary register set.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","2 (All bits set)","Usage","questionableRegister = status.questionable.unstable_output.condition","questionableRegister = status.questionable.unstable_output.enable","questionableRegister = status.questionable.unstable_output.event","questionableRegister = status.questionable.unstable_output.ntr","questionableRegister = status.questionable.unstable_output.ptr","status.questionable.unstable_output.enable = questionableRegister","status.questionable.unstable_output.ntr = questionableRegister","status.questionable.unstable_output.ptr = questionableRegister ","operationRegister","The status of the questionable status unstable output summary register; a zero (0) indicates no bits set (also send 0 to clear all bits); the only other valid value is 2","Details","These attributes are used to read or write to the questionable status unstable output summary registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","Not used","B1","status.questionable.unstable_output.SMUA","Set bit indicates that an unstable output condition was detected on SMU A.","Bit B1 decimal value: 2","Binary value: 0000 0010","B2 to B15","Not used","As an example, to set bit B1 of the questionable status unstable output summary enable register, set status.questionable.instrument.enable = status.questionable.instrument.SMUA.","In addition to the above constant, questionableRegister can be set to the decimal value of the bit to set.","Example","status.questionable.unstable_output.enable = status.questionable.unstable_output.SMUA","Uses the constant to set the SMU A bit in the questionable status unstable output summary enable register bit.","Also see","Questionable Status Registers","status.questionable.*","status.questionable.unstable_output.*","92998.htm"); +Page[409]=new Array("This attribute stores the service request (SRQ) enable register.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Status reset","Not saved","0","Usage","requestSRQEnableRegister = status.request_enable","status.request_enable = requestSRQEnableRegister","requestSRQEnableRegister","The status of the service request (SRQ) enable register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","This attribute is used to read or write to the service request enable register. Reading the service request enable register returns a value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">","*","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","status.MEASUREMENT_SUMMARY_BIT","status.MSB","Set summary bit indicates that an enabled event in the Measurement Event Register has occurred.","Bit B0 decimal value: 1","B1","status.SYSTEM_SUMMARY_BIT","status.SSB","Set summary bit indicates that an enabled event in the System Summary Register has occurred.","Bit B1 decimal value: 2","B2","status.ERROR_AVAILABLE","status.EAV","Set summary bit indicates that an error or status message is present in the error queue.","Bit B2 decimal value: 4","B3","status.QUESTIONABLE_SUMMARY_BIT","status.QSB","Set summary bit indicates that an enabled event in the Questionable Status Register has occurred.","Bit B3 decimal value: 8","B4","status.MESSAGE_AVAILABLE","status.MAV","Set summary bit indicates that a response message is present in the output queue.","Bit B4 decimal value: 16","B5","status.EVENT_SUMMARY_BIT","status.ESB","Set summary bit indicates that an enabled event in the Standard Event Status Register has occurred.","Bit B5 decimal value: 32","B6","Not used","B7","status.OPERATION_SUMMARY_BIT","status.OSB","Set summary bit indicates that an enabled event in the Operation Status Register has occurred.","Bit B7 decimal value: 128","As an example, to set bit B0 of the service request enable register, set status.request_enable = status.MSB.","In addition to the above values, requestSRQEnableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set requestSRQEnableRegister to the sum of their decimal values. For example, to set bits B0 and B7, set requestSRQEnableRegister to 129 (1 + 128).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Example 1","requestSRQEnableRegister = status.MSB + status.OSB","status.request_enable = requestSRQEnableRegister","Uses constants to set the MSB and OSB bits of the service request (SRQ) enable register.","Example 2","-- decimal 129 = binary 10000001","requestSRQEnableRegister = 129","status.request_enable = requestSRQEnableRegister","Uses the decimal value to set the MSB and OSB bits of the service request (SRQ) enable register.","Also see","Status byte and service request (SRQ)","status.condition","status.system.*","status.request_enable","92663.htm"); +Page[410]=new Array("This attribute stores the service request (SRQ) event register.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not saved","0","Usage","requestSRQEventRegister = status.request_event","requestSRQEventRegister","The status of the request event register; a zero (0) indicates no bits set; other values indicate various bit settings","Details","This attribute is used to read the service request event register, which is returned as a numeric value. Reading this register returns a value. The binary equivalent of the value of this attribute indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B7. For example, if a value of 1.29000e+02 (which is 129) is read as the value of this register, the binary equivalent is 1000 0001. This value indicates that bit B0 and bit B7 are set.","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">","*","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","The returned value can indicate one or more status events occurred.","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value and description","B0","status.MEASUREMENT_SUMMARY_BIT","status.MSB","Set summary bit indicates that an enabled event in the Measurement Event Register has occurred.","Bit B0 decimal value: 1","B1","status.SYSTEM_SUMMARY_BIT","status.SSB","Set summary bit indicates that an enabled event in the System Summary Register has occurred. ","Bit B1 decimal value: 2","B2","status.ERROR_AVAILABLE","status.EAV","Set summary bit indicates that an error or status message is present in the error queue.","Bit B2 decimal value: 4","B3","status.QUESTIONABLE_SUMMARY_BIT","status.QSB","Set summary bit indicates that an enabled event in the Questionable Status Register has occurred.","Bit B3 decimal value: 8","B4","status.MESSAGE_AVAILABLE","status.MAV","Set summary bit indicates that a response message is present in the output queue.","Bit B4 decimal value: 16","B5","status.EVENT_SUMMARY_BIT","status.ESB","Set summary bit indicates that an enabled event in the Standard Event Status Register has occurred.","Bit B5 decimal value: 32","B6","Not used","B7","status.OPERATION_SUMMARY_BIT","status.OSB","Set summary bit indicates that an enabled event in the Operation Status Register has occurred.","Bit B7 decimal value: 128","In addition to the above constants, requestEventRegister can be set to the decimal value of the bits set. When more than one bit of the register is set, requestEventRegister contains the sum of their decimal values. For example, if 129 is returned, bits B0 and B7 are set (1 + 128).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Example","requestEventRegister = status.request_event","print(requestEventRegister)","Reads the status request event register.","Sample output:","1.29000e+02","Converting this output (129) to its binary equivalent yields 1000 0001.","Therefore, this output indicates that the set bits of the status request event register are presently B0 (MSB) and B7 (OSB).","Also see","status.condition","status.system.*","Status byte and service request (SRQ)","status.request_event","92664.htm"); +Page[411]=new Array("This function resets all bits in the status model.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","status.reset()","Details","This function clears all status data structure registers (enable, event, NTR, and PTR) to their default values. For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers.","Example","status.reset()","Resets the instrument status model.","Also see","Status model","status.reset()","15861.htm"); +Page[412]=new Array("These attributes manage the standard event status register set of the status model.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","253 (All bits set)","Usage","standardRegister = status.standard.condition","standardRegister = status.standard.enable","standardRegister = status.standard.event","standardRegister = status.standard.ntr","standardRegister = status.standard.ptr","status.standard.enable = standardRegister","status.standard.ntr = standardRegister","status.standard.ptr = standardRegister","standardRegister","The status of the standard event status register; a zero (0) indicates no bits set (also send 0 to clear all bits); other values indicate various bit settings","Details","These attributes are used to read or write to the standard event status registers. Reading a status register returns a value. The binary equivalent of the returned value indicates which register bits are set. The least significant bit of the binary number is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","B0","status.standard.OPERATION_COMPLETE","status.standard.OPC","Set bit indicates that all pending selected instrument operations are completed and the instrument is ready to accept new commands. The bit is set in response to an *OPC command. The opc() function can be used in place of the *OPC command.","Bit B0 decimal value: 1","B1","Not used","B2","status.standard.QUERY_ERROR","status.standard.QYE","Set bit indicates that you attempted to read data from an empty Output Queue.","Bit B2 decimal value: 4","B3","status.standard.DEVICE_DEPENDENT_ERROR","status.standard.DDE","Set bit indicates that an instrument operation did not execute properly due to some internal condition. ","Bit B3 decimal value: 8","B4","status.standard.EXECUTION_ERROR","status.standard.EXE","Set bit indicates that the instrument detected an error while trying to execute a command.","Bit B4 decimal value: 16","B5","status.standard.COMMAND_ERROR","status.standard.CME","Set bit indicates that a command error has occurred. Command errors include:","IEEE Std 488.2 syntax error: Instrument received a message that does not follow the defined syntax of the IEEE Std 488.2 standard.","Semantic error: Instrument received a command that was misspelled or received an optional IEEE Std 488.2 command that is not implemented.","GET error: The instrument received a Group Execute Trigger (GET) inside a program message.","Bit B5 decimal value: 32","B6","status.standard.USER_REQUEST","status.standard.URQ","Set bit indicates that the LOCAL key on the instrument front panel was pressed.","Bit B6 decimal value: 64","B7","status.standard.POWER_ON","status.standard.PON","Set bit indicates that the instrument has been turned off and turned back on since the last time this register has been read.","Bit B7 decimal value: 128","B8 to B15","Not used","As an example, to set bit B0 of the standard event status enable register, set status.standard.enable = status.standard.OPC.","In addition to the above constants, standardRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set standardRegister to the sum of their decimal weights. For example, to set bits B0 and B4, set standardRegister to 17 (which is the sum of 1 + 16).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Example 1","standardRegister = status.standard.OPC + status.standard.EXE","status.standard.enable = standardRegister","Uses constants to set the OPC and EXE bits of the standard event status enable register.","Example 2","-- decimal 17 = binary 0001 0001","standardRegister = 17","status.standard.enable = standardRegister","Uses the decimal value to set the OPC and EXE bits of the standard event status enable register.","Also see","Standard Event Register ","status.standard.*","15862.htm"); +Page[413]=new Array("These attributes manage the TSP-Link® system summary register of the status model for nodes 1 through 14. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","32,767 (All bits set)","Usage","enableRegister = status.system.condition","enableRegister = status.system.enable","enableRegister = status.system.event","enableRegister = status.system.ntr","enableRegister = status.system.ptr","status.system.enable = enableRegister","status.system.ntr = enableRegister","status.system.ptr = enableRegister","enableRegister","The status of the system summary register; a zero (0) indicates no bits set; other values indicate various bit settings","Details","In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","status.system.EXTENSION_BIT","status.system.EXT","1","B1","status.system.NODE1","2","B2","status.system.NODE2","4","B3","status.system.NODE3","8","B4","status.system.NODE4","16","B5","status.system.NODE5","32","B6","status.system.NODE6","64","B7","status.system.NODE7","128","B8","status.system.NODE8","256","B9","status.system.NODE9","512","B10","status.system.NODE10","1,024","B11","status.system.NODE11","2,048","B12","status.system.NODE12","4,096","B13","status.system.NODE13","8,192","B14","status.system.NODE14","16,384","B15","Not used","Not applicable","As an example, to set bit B0 of the system summary status enable register, set status.system.enable = status.system.enable.EXT.","In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","enableRegister = status.system.NODE11 + status.system.NODE14","status.system.enable = enableRegister","Uses constants to set bits B11 and B14 of the system summary enable register.","Example 2","-- decimal 18432 = binary 0100 1000 0000 0000","enableRegister = 18432","status.system.enable = enableRegister","Uses the decimal value to set bits B11 and B14 of the system summary enable register.","Also see","status.system2.*","System summary and standard event registers","status.system.*","15863.htm"); +Page[414]=new Array("These attributes manage the TSP-Link® system summary register of the status model for nodes 15 through 28. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","32,767 (All bits set)","Usage","enableRegister = status.system2.condition","enableRegister = status.system2.enable","enableRegister = status.system2.event","enableRegister = status.system2.ntr","enableRegister = status.system2.ptr","status.system2.enable = enableRegister","status.system2.ntr = enableRegister","status.system2.ptr = enableRegister","enableRegister","The status of the system summary 2 register; a zero (0) indicates no bits set; other values indicate various bit settings","Details","In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","status.system2.EXTENSION_BIT","status.system2.EXT","1","B1","status.system2.NODE15","2","B2","status.system2.NODE16","4","B3","status.system2.NODE17","8","B4","status.system2.NODE18","16","B5","status.system2.NODE19","32","B6","status.system2.NODE20","64","B7","status.system2.NODE21","128","B8","status.system2.NODE22","256","B9","status.system2.NODE23","512","B10","status.system2.NODE24","1,024","B11","status.system2.NODE25","2,048","B12","status.system2.NODE26","4,096","B13","status.system2.NODE27","8,192","B14","status.system2.NODE28","16,384","B15","Not used","Not applicable","As an example, to set bit B0 of the system summary 2 enable register, set status.system2.enable = status.system2.EXT.","In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","enableRegister = status.system2.NODE25 + status.system2.NODE28","status.system2.enable = enableRegister ","Uses constants to set bits B11 and B14 of the system summary 2 enable register.","Example 2","-- decimal 18432 = binary 0100 1000 0000 0000","enableRegister = 18432","status.system2.enable = enableRegister","Uses the decimal value to set bits B11 and B14 of the system summary 2 enable register.","Also see","status.system.*","status.system3.*","System summary and standard event registers","status.system2.*","15864.htm"); +Page[415]=new Array("These attributes manage the TSP-Link® system summary register of the status model for nodes 29 through 42. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","32,767 (All bits set)","Usage","enableRegister = status.system3.condition","enableRegister = status.system3.enable","enableRegister = status.system3.event","enableRegister = status.system3.ntr","enableRegister = status.system3.ptr","status.system3.enable = enableRegister","status.system3.ntr = enableRegister","status.system3.ptr = enableRegister","enableRegister","The status of the system summary 3 register; a zero (0) indicates no bits set; other values indicate various bit settings","Details","In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0 and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","status.system3.EXTENSION_BIT","status.system3.EXT","1","B1","status.system3.NODE29","2","B2","status.system3.NODE30","4","B3","status.system3.NODE31","8","B4","status.system3.NODE32","16","B5","status.system3.NODE33","32","B6","status.system3.NODE34","64","B7","status.system3.NODE35","128","B8","status.system3.NODE36","256","B9","status.system3.NODE37","512","B10","status.system3.NODE38","1,024","B11","status.system3.NODE39","2,048","B12","status.system3.NODE40","4,096","B13","status.system3.NODE41","8,192","B14","status.system3.NODE42","16,384","B15","Not used","Not applicable","As an example, to set bit B0 of the system summary 3 enable register, set status.system3.enable = status.system3.EXT.","In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","enableRegister = status.system3.NODE39 + status.system3.NODE42","status.system3.enable = enableRegister","Uses constants to set bits B11 and B14 of the system summary 3 enable register.","Example 2","-- decimal 18432 = binary 0100 1000 0000 0000","enableRegister = 18432","status.system3.enable = enableRegister","Uses the decimal value to set bits B11 and B14 of the system summary 3 enable register.","Also see","status.system2.*","status.system4.*","System summary and standard event registers","status.system3.*","15865.htm"); +Page[416]=new Array("These attributes manage the TSP-Link® system summary register of the status model for nodes 43 through 56. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","32,767 (All bits set)","Usage","enableRegister = status.system4.condition","enableRegister = status.system4.enable","enableRegister = status.system4.event","enableRegister = status.system4.ntr","enableRegister = status.system4.ptr","status.system4.enable = enableRegister","status.system4.ntr = enableRegister","status.system4.ptr = enableRegister","enableRegister","The status of the system summary 4 register; a zero (0) indicates no bits set; other values indicate various bit settings","Details","In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.29000e+02 (which is 129) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0001. This value indicates that bit B0 and bit B7 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","1","0","0","0","0","0","0","1","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","status.system4.EXTENSION_BIT","status.system4.EXT","1","B1","status.system4.NODE43","2","B2","status.system4.NODE44","4","B3","status.system4.NODE45","8","B4","status.system4.NODE46","16","B5","status.system4.NODE47","32","B6","status.system4.NODE48","64","B7","status.system4.NODE49","128","B8","status.system4.NODE50","256","B9","status.system4.NODE51","512","B10","status.system4.NODE52","1,024","B11","status.system4.NODE53","2,048","B12","status.system4.NODE54","4,096","B13","status.system4.NODE55","8,192","B14","status.system4.NODE56","16,384","B15","Not used","Not applicable","As an example, to set bit B0 of the system summary 4 enable register, set status.system4.enable = status.system4.enable.EXT.","In addition to the above constants, enableRegister can be set to the decimal value of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal values. For example, to set bits B11 and B14, set enableRegister to 18,432 (which is the sum of 2,048 + 16,384). ","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","enableRegister = status.system4.NODE53 + status.system4.NODE56","status.system2.enable = enableRegister ","Uses constants to set bit B11 and bit B14 of the system summary 4 enable register.","Example 2","-- decimal 18432 = binary 0100 1000 0000 0000","enableRegister = 18432","status.system4.enable = enableRegister","Uses a decimal value to set bit B11 and bit B14 of the system summary 4 enable register.","Also see","status.system3.*","status.system5.*","System summary and standard event registers","status.system4.*","15866.htm"); +Page[417]=new Array("These attributes manage the TSP-Link® system summary register of the status model for nodes 57 through 64. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute","- -","- -","- -","- -",".condition (R)","Yes","Not applicable","Not saved","Not applicable",".enable (RW)","Yes","Status reset","Not saved","0",".event (R)","Yes","Status reset","Not saved","0",".ntr (RW)","Yes","Status reset","Not saved","0",".ptr (RW)","Yes","Status reset","Not saved","510 (All bits set)","Usage","enableRegister = status.system5.condition","enableRegister = status.system5.enable","enableRegister = status.system5.event","enableRegister = status.system5.ntr","enableRegister = status.system5.ptr","status.system5.enable = enableRegister","status.system5.ntr = enableRegister","status.system5.ptr = enableRegister","enableRegister","The status of the system summary 5 register; a zero (0) indicates no bits set; other values indicate various bit settings","Details","In an expanded system (TSP-Link), these attributes are used to read or write to the system summary registers. They are set using a constant or a numeric value, but are returned as a numeric value. The binary equivalent of the value indicates which register bits are set. In the binary equivalent, the least significant bit is bit B0, and the most significant bit is bit B15. For example, if a value of 1.30000e+02 (which is 130) is read as the value of the condition register, the binary equivalent is 0000 0000 1000 0010. This value indicates that bit B1 and bit B7 are set.","B15","B14","B13","B12","B11","B10","B9","B8","B7","B6","B5","B4","B3","B2","B1","B0","**",">",">",">",">",">",">",">",">",">",">",">",">",">",">","*","0","0","0","0","0","0","0","0","1","0","0","0","0","0","1","0","* Least significant bit
** Most significant bit","For information about .condition, .enable, .event, .ntr, and .ptr registers, refer to Status register set contents and Enable and transition registers. The individual bits of this register are defined in the following table.","Bit","Value","Decimal value","B0","Not used","Not applicable","B1","status.system5.NODE57","2","B2","status.system5.NODE58","4","B3","status.system5.NODE59","8","B4","status.system5.NODE60","16","B5","status.system5.NODE61","32","B6","status.system5.NODE62","64","B7","status.system5.NODE63","128","B8","status.system5.NODE64","256","B9 to B15","Not used","Not applicable","As an example, to set bit B1 of the system summary 5 enable register, set status.system5.enable = status.system5.NODE57.","In addition to the above constants, enableRegister can be set to the numeric equivalent of the bit to set. To set more than one bit of the register, set enableRegister to the sum of their decimal weights. For example, to set bits B1 and B4, set enableRegister to 18 (which is the sum of 2 + 16).","Bit","B7","B6","B5","B4","B3","B2","B1","B0","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","128","64","32","16","8","4","2","1","Weights","(27)","(26)","(25)","(24)","(23)","(22)","(21)","(20)","Bit","B15","B14","B13","B12","B11","B10","B9","B8","Binary value","0/1","0/1","0/1","0/1","0/1","0/1","0/1","0/1","Decimal","32,768","16,384","8,192","4,096","2,048","1,024","512","256","Weights","(215)","(214)","(213)","(212)","(211)","(210)","(29)","(28)","Example 1","enableRegister = status.system5.NODE57 + status.system5.NODE60","status.system2.enable = enableRegister ","Uses constants to set bits B1 and B4 of the system summary 5 enable register.","Example 2","-- decimal 18 = binary 0000 0000 0001 0010","enableRegister = 18","status.system5.enable = enableRegister","Uses the decimal value to set bits B1 and B4 of the system summary 5 enable register.","Also see","status.system4.*","System summary and standard event registers","status.system5.*","15867.htm"); +Page[418]=new Array("This KISweep factory script function performs a linear current sweep with voltage measured at every step (point).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","SweepILinMeasureV(smua, starti, stopi, stime, points)","starti","Sweep start current in amperes","stopi","Sweep stop current in amperes","stime","Settling time in seconds; occurs after stepping the source and before making a measurement","points","Number of sweep points (must be ³2)","Details","Data for voltage measurements, current source values, and timestamps are stored in smua.nvbuffer1.","If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.","Performs a linear current sweep with voltage measured at every step (point):","Sets the SMU to output starti amperes, allows the source to settle for stime seconds, and then makes a voltage measurement.","Sets the SMU to output the next amperes step, allows the source to settle for stime seconds, and then makes a voltage measurement.","Repeats the above sequence until the voltage is measured on the stopi amperes step.","The linear step size is automatically calculated as follows:","step = (stopi – starti) / (points – 1)","Example","SweepILinMeasureV(smua, -1e-3, 1e-3, 0, 100)","This function performs a 100-point linear current sweep starting at -1 mA and stopping at +1 mA. Voltage is measured at every step (point) in the sweep. Because stime is set for 0 s, voltage is measured as quickly as possible after each current step.","Also see","KISweep factory script","SweepILinMeasureV()","12177.htm"); +Page[419]=new Array("This KISweep factory script function performs a current list sweep with voltage measured at every step (point).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","SweepIListMeasureV(smua, ilist, stime, points)","ilist","Arbitrary list of current source values; ilist = {value1, value2, ...valueN}","stime","Settling time in seconds; occurs after stepping the source and before making a measurement","points","Number of sweep points (must be ³ 2)","Details","Data for voltage measurements, current source values, and timestamps are stored in smua.nvbuffer1.","If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.","Performs a current list sweep with voltage measured at every step (point):","Sets the SMU to output ilist amperes value, allows the source to settle for stime seconds, and then performs a voltage measurement.","Sets the SMU to output the next ilist step, allows the source to settle for stime seconds, and then performs a voltage measurement.","Repeats the above sequence until the voltage is measured for the last amperes value. The last point in the list to be measured is points.","Example","testilist = {-100e-9, 100e-9, -1e-6, 1e-6, -1e-3, 1e-3}","SweepIListMeasureV(smua, testilist, 500e-3, 6)","This function performs a six‑point current list sweep starting at the first point in testilist. Voltage is measured at every step (point) in the sweep. The source is allowed to settle on each step for 500 ms before a measurement is performed.","Also see","KISweep factory script","SweepIListMeasureV()","12190.htm"); +Page[420]=new Array("This KISweep factory script function performs a logarithmic current sweep with voltage measured at every step (point).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","SweepILogMeasureV(smua, starti, stopi, stime, points)","starti","Sweep start current in amperes","stopi","Sweep stop current in amperes","stime","Settling time in seconds; occurs after stepping the source and before making a measurement","points","Number of sweep points (must be ³ 2)","Details","Data for voltage measurements, current source values, and timestamps are stored in smua.nvbuffer1.","If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.","Performs a logarithmic current sweep with voltage measured at every step (point):","Sets the SMU to output starti amperes value, allows the source to settle for stime seconds, and then performs a voltage measurement.","Sets the SMU to output the next amperes step, allows the source to settle for stime seconds, and then performs a voltage measurement.","Repeats the above sequence until the voltage is measured on the stopi amperes step.","The source level at each step (SourceStepLevel) is automatically calculated as follows:","MeasurePoint = The step point number for a measurement ","For example, for a five-point sweep (points = 5), a measurement is performed at MeasurePoint 1, 2, 3, 4, and 5.","LogStepSize = (log10(stopi) – log10(starti)) / (points – 1)","LogStep = (MeasurePoint – 1) * (LogStepSize)","SourceStepLevel = antilog(LogStep) * starti","Example","SweepILogMeasureV(smua, 0.01, 0.1, 0.001, 5)","This function performs a five‑point linear current sweep starting at 10 mA and stopping at 100 mA. Voltage is measured at every step (point) in the sweep. The source is allowed to settle on each step for 1 ms before a measurement is made.","The following table contains log values and corresponding source levels for the five‑point logarithmic sweep:","MeasurePoint","LogStepSize","LogStep","SourceStepLevel","1","0.25","0.0","0.01 A","2","0.25","0.25","0.017783 A","3","0.25","0.5","0.031623 A","4","0.25","0.75","0.056234 A","5","0.25","1.0","0.1 A","Also see","KISweep factory script","SweepILogMeasureV()","12184.htm"); +Page[421]=new Array("This KISweep factory script function performs a linear voltage sweep with current measured at every step (point).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","SweepVLinMeasureI(smua, startv, stopv, stime, points)","startv","Sweep start voltage in volts","stopv","Sweep stop voltage in volts","stime","Settling time in seconds; occurs after stepping the source and before making a measurement","points","Number of sweep points (must be ³ 2)","Details","Data for current measurements, voltage source values, and timestamps are stored in smua.nvbuffer1.","If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.","Performs a linear voltage sweep with current measured at every step (point):","Sets the SMU to output startv amperes, allows the source to settle for stime seconds, and then makes a current measurement.","Sets the SMU to output the next amperes step, allows the source to settle for stime seconds, and then makes a voltage measurement.","Repeats the above sequence until the voltage is measured on the stopv amperes step.","The linear step size is automatically calculated as follows:","step = (stopv – startv) / (points – 1)","Example","SweepVLinMeasureI(smua, -1, 1, 1e-3, 1000)","This function performs a 1000-point linear voltage sweep starting at -1 V and stopping at +1 V. Current is measured at every step (point) in the sweep after a 1 ms source settling period.","Also see","KISweep factory script","SweepVLinMeasureI()","12181.htm"); +Page[422]=new Array("This KISweep factory script function performs a voltage list sweep with current measured at every step (point).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","SweepVListMeasureI(smua, vlist, stime, points)","vlist","Arbitrary list of voltage source values; vlist = {value1, value2, ... valueN}","stime","Settling time in seconds; occurs after stepping the source and before making a measurement","points","Number of sweep points (must be ³ 2)","Details","Data for current measurements, voltage source values, and timestamps are stored in smua.nvbuffer1.","If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.","Performs a voltage list sweep with current measured at every step (point):","Sets the SMU to output vlist volts value, allows the source to settle for stime seconds, and then performs a current measurement.","Sets the SMU to output the next vlist volts value, allows the source to settle for stime seconds, and then performs a current measurement.","Repeats the above sequence until the current is measured for the last volts value. The last point in the list to be measured is points.","Example","myvlist = {-0.1, 0.1, -1, 1, -6, 6, -40, 40, 0, 0}","SweepVListMeasureI(smua, myvlist, 500E-3, 10)","This function performs a 10‑point voltage list sweep starting at the first point in myvlist. Current is measured at every step (point) in the sweep. The source will be allowed to settle on each step for 500 ms before a measurement is performed.","Also see","KISweep factory script","SweepVListMeasureI()","19138.htm"); +Page[423]=new Array("This KISweep factory script function performs a logarithmic voltage sweep with current measured at every step (point).","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","SweepVLogMeasureI(smua, startv, stopv, stime, points)","startv","Sweep start voltage in volts","stopv","Sweep stop voltage in volts","stime","Settling time in seconds; occurs after stepping the source and before making a measurement","points","Number of sweep points (must be ³ 2)","Details","Data for current measurements, voltage source values, and timestamps are stored in smua.nvbuffer1.","If all parameters are omitted when this function is called, this function is executed with the parameters set to the default values.","Performs a logarithmic voltage sweep with current measured at every step (point):","Sets the SMU to output startv amperes, allows the source to settle for stime seconds, and then makes a current measurement.","Sets the SMU to output the next volts step, allows the source to settle for stime seconds, and then makes a current measurement.","Repeats the above sequence until the voltage is measured on the stopv volts step.","The source level at each step (SourceStepLevel) is automatically calculated as follows:","MeasurePoint = The step point number for a measurement ","For example, for a five-point sweep (points = 5), a measurement is made at MeasurePoint 1, 2, 3, 4, and 5.","LogStepSize = (log10(stopi) – log10(starti)) / (points – 1)","LogStep = (MeasurePoint – 1) * (LogStepSize)","SourceStepLevel = antilog(LogStep) * startv","Example","SweepVLogMeasureI(smua, 1, 10, 0.001, 5)","This function performs a five‑point logarithmic voltage sweep starting at 1 V and stopping at 10 V. Current is measured at every step (point) in the sweep after a 1 ms source settling period.","The following table contains log values and corresponding source levels for the five‑point logarithmic sweep:","MeasurePoint","LogStepSize","LogStep","SourceStepLevel","1","0.25","0.0","1.0000 V","2","0.25","0.25","1.7783 V","3","0.25","0.5","3.1623 V","4","0.25","0.75","5.6234 V","5","0.25","1.0","10.000 V","Also see","KISweep factory script","SweepVLogMeasureI()","12192.htm"); +Page[424]=new Array("This function measures the elapsed time since the timer was last reset.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","time = timer.measure.t()","time","The elapsed time in seconds (1 µs resolution)","Example 1","timer.reset()","-- (intervening code)","time = timer.measure.t()","print(time)","This example resets the timer and measures the time since the reset.","Output:","1.469077e+01","The output will vary. The above output indicates that timer.measure.t() was executed 14.69077 seconds after timer.reset().","Example 2","beeper.enable = beeper.ON","beeper.beep(0.5, 2400)","print("reset timer")","timer.reset()","delay(0.5)","dt = timer.measure.t()","print("timer after delay:", dt)","beeper.beep(0.5, 2400)","Enable the beeper.","Emit a beep and set the beeper.","Reset the timer.","Set a delay.","Verify the duration of the delay before emitting another beep.","Output:","reset timer","timer after delay: 5.00e-01","Also see","timer.reset()","timer.measure.t()","15281.htm"); +Page[425]=new Array("This function resets the timer to zero (0) seconds.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","timer.reset()","Example","timer.reset()","-- (intervening code)","time = timer.measure.t()","print(time)","Resets the timer and then measures the time since the reset.","Output:","1.469077e+01","The above output indicates that timer.measure.t() was executed 14.69077 seconds after timer.reset().","Also see","timer.measure.t()","timer.reset()","15282.htm"); +Page[426]=new Array("This function clears the blender event detector and resets the overrun indicator of blender N.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","trigger.blender[N].clear()","N","The blender number (up to six)","Details","This command sets the blender event detector to the undetected state and resets the overrun indicator of the event detector.","Example","trigger.blender[2].clear()","Clears the event detector for blender 2.","Also see","None","trigger.blender[N].clear()","15785.htm"); +Page[427]=new Array("This constant contains the trigger blender event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = trigger.blender[N].EVENT_ID","eventID","Trigger event number","N","The blender number (up to six)","Details","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to trigger events from this trigger blender.","Example","digio.trigger[1].stimulus = trigger.blender[2].EVENT_ID","Set the trigger stimulus of digital I/O trigger 1 to be controlled by the trigger blender 2 event.","Also see","None","trigger.blender[N].EVENT_ID","15786.htm"); +Page[428]=new Array("This attribute selects whether the blender performs OR operations or AND operations.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Trigger blender N reset
Recall setup","Not saved","false (AND mode)","Usage","orenable = trigger.blender[N].orenable","trigger.blender[N].orenable = orenable","orenable","The type of operation:","true: OR operation","false: AND operation","N","The blender number (up to six)","Details","This command selects whether the blender waits for any one event (OR) or waits for all selected events (AND) before signaling an output event.","Example","trigger.blender[1].orenable = true","trigger.blender[1].stimulus[1] = digio.trigger[3].EVENT_ID","trigger.blender[1].stimulus[2] = digio.trigger[5].EVENT_ID","Generate a trigger blender 1 event when a digital I/O trigger happens on line 3 or 5.","Also see","trigger.blender[N].reset()","trigger.blender[N].orenable","15787.htm"); +Page[429]=new Array("This attribute indicates whether or not an event was ignored because of the event detector state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Instrument reset
Trigger blender N clear
Trigger blender N reset","Not applicable","Not applicable","Usage","overrun = trigger.blender[N].overrun","overrun","Trigger blender overrun state (true or false)","N","The blender number (up to six)","Details","Indicates if an event was ignored because the event detector was already in the detected state when the event occurred. This is an indication of the state of the event detector that is built into the event blender itself.","This command does not indicate if an overrun occurred in any other part of the trigger model or in any other trigger object that is monitoring the event. It also is not an indication of an action overrun.","Example","print(trigger.blender[1].overrun)","If an event was ignored, the output is true.","If an event was not ignored, the output is false.","Also see","trigger.blender[N].reset()","trigger.blender[N].overrun","15788.htm"); +Page[430]=new Array("This function resets some of the trigger blender settings to their factory defaults.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","trigger.blender[N].reset()","N","The trigger event blender (up to six)","Details","The trigger.blender[N].reset() function resets the following attributes to their factory defaults:","trigger.blender[N].orenable","trigger.blender[N].stimulus[M]","It also clears trigger.blender[N].overrun.","Example","trigger.blender[1].reset()","Resets the trigger blender 1 settings to factory defaults.","Also see","trigger.blender[N].orenable","trigger.blender[N].overrun","trigger.blender[N].stimulus[M]","trigger.blender[N].reset()","17666.htm"); +Page[431]=new Array("This attribute specifies the events that trigger the blender.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Trigger blender N reset","Not applicable","trigger.EVENT_NONE","Usage","eventID = trigger.blender[N].stimulus[M]","trigger.blender[N].stimulus[M] = eventID","eventID","The event that triggers the blender action; see Details","N","An integer representing the trigger event blender (up to six)","M","An integer representing the stimulus index (1 to 4)","Details","There are four stimulus inputs that can each select a different event. The eventID parameter can be the event ID of any trigger event.","Use zero to disable the blender input. ","The eventID parameter may be one of the existing trigger event IDs shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Example","digio.trigger[3].mode = digio.TRIG_FALLING","digio.trigger[5].mode = digio.TRIG_FALLING","trigger.blender[1].orenable = true","trigger.blender[1].stimulus[1] = digio.trigger[3].EVENT_ID","trigger.blender[1].stimulus[2] = digio.trigger[5].EVENT_ID","Generate a trigger blender 1 event when a digital I/O trigger happens on line 3 or 5.","Also see","trigger.blender[N].reset()","trigger.blender[N].stimulus[M]","17684.htm"); +Page[432]=new Array("This function waits for a blender trigger event to occur.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","triggered = trigger.blender[N].wait(timeout)","triggered","Trigger detection indication for blender","N","The trigger blender (up to six) on which to wait","timeout","Maximum amount of time in seconds to wait for the trigger blender event","Details","This function waits for an event blender trigger event. If one or more trigger events were detected since the last time trigger.blender[N].wait() or trigger.blender[N].clear() was called, this function returns immediately.","After detecting a trigger with this function, the event detector automatically resets and rearms. This is true regardless of the number of events detected.","Example","digio.trigger[3].mode = digio.TRIG_FALLING","digio.trigger[5].mode = digio.TRIG_FALLING","trigger.blender[1].orenable = true","trigger.blender[1].stimulus[1] = digio.trigger[3].EVENT_ID","trigger.blender[1].stimulus[2] = digio.trigger[5].EVENT_ID","print(trigger.blender[1].wait(3))","Generate a trigger blender 1 event when a digital I/O trigger happens either on line 3 or 5.","Wait three seconds while checking if trigger blender 1 event has occurred.","If the blender trigger event has happened, then true is output. If the trigger event has not happened, then false is output after the timeout expires.","Also see","trigger.blender[N].clear()","trigger.blender[N].wait()","15790.htm"); +Page[433]=new Array("This function clears the command interface trigger event detector.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","trigger.clear()","Details","The trigger event detector indicates if a trigger event has been detected since the last trigger.wait() call. trigger.clear() clears the trigger event detector and discards the history of command interface trigger events.","Also see","trigger.wait()","trigger.clear()","15791.htm"); +Page[434]=new Array("This constant contains the command interface trigger event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = trigger.EVENT_ID","eventID","The event ID for the command interface triggers","Details","You can set the stimulus of any trigger object to the value of this constant to have the trigger object respond to command interface trigger events.","Example","trigger.timer[1].stimulus = trigger.EVENT_ID","Sets the trigger stimulus of trigger timer 1 to the command interface trigger event.","Also see","None","trigger.EVENT_ID","15792.htm"); +Page[435]=new Array("This function generates a trigger event.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","trigger.generator[N].assert()","N","The generator number (1 or 2)","Details","Use this function to directly trigger events from the command interface or a script. For example, you can trigger a sweep while the instrument is under script control.","Example","trigger.generator[2].assert()","Generates a trigger event on generator 2.","Also see","trigger.generator[N].EVENT_ID","trigger.generator[N].assert()","29218.htm"); +Page[436]=new Array("This constant identifies the trigger event generated by the trigger event generator.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = trigger.generator[N].EVENT_ID","eventID","The trigger event number","N","The generator number (1 or 2)","Details","This constant is an identification number that identifies events generated by this generator.","To have another trigger object respond to trigger events generated by this generator, set the other object's stimulus attribute to the value of this constant.","Example","digio.trigger[5].stimulus = trigger.generator[2].EVENT_ID","Uses a trigger event on generator 2 to be the stimulus for digital I/O trigger line 5.","Also see","trigger.generator[N].assert()","trigger.generator[N].EVENT_ID","29219.htm"); +Page[437]=new Array("This function clears the timer event detector and overrun indicator for the specified trigger timer number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","trigger.timer[N].clear()","N","Trigger timer number (1 to 8)","Details","This command sets the timer event detector to the undetected state and resets the overrun indicator.","Example","trigger.timer[1].clear()","Clears trigger timer 1.","Also see","trigger.timer[N].count","trigger.timer[N].clear()","15793.htm"); +Page[438]=new Array("This attribute sets the number of events to generate each time the timer generates a trigger event.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup
Trigger timer N reset","Not saved","1","Usage","count = trigger.timer[N].count","trigger.timer[N].count = count","count","Number of times to repeat the trigger (0 to 1,048,575)","N","Trigger timer number (1 to 8)","Details","If the count is set to a number greater than 1, the timer automatically starts the next trigger timer delay at the expiration of the previous delay.","Set the count to zero (0) to cause the timer to generate trigger events indefinitely.","If you use the trigger timer with a trigger model, make sure the count value is the same or more than any count values expected in the trigger model.","Example","print(trigger.timer[1].count)","Read trigger count for timer number 1.","Also see","trigger.timer[N].clear()","trigger.timer[N].delay","trigger.timer[N].reset()","trigger.timer[N].count","15820.htm"); +Page[439]=new Array("This attribute sets and reads the timer delay.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup
Trigger timer N reset","Not saved","10e-6 (10 µs)","Usage","interval = trigger.timer[N].delay","trigger.timer[N].delay = interval","interval","Delay interval in seconds (0.5 µs to 100 ks)","N","Trigger timer number (1 to 8)","Details","Once the timer is enabled, each time the timer is triggered, it uses this delay period.","Assigning a value to this attribute is equivalent to:","trigger.timer[N].delaylist = {interval}","This creates a delay list of one value.","Reading this attribute returns the delay interval that will be used the next time the timer is triggered.","Example","trigger.timer[1].delay = 50e-6","Set the trigger timer 1 to delay for 50 µs.","Also see","trigger.timer[N].reset()","trigger.timer[N].delay","15794.htm"); +Page[440]=new Array("This attribute sets an array of timer intervals.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup
Trigger timer N reset","Not saved","10e-6 (10 µs)","Usage","intervals = trigger.timer[N].delaylist","trigger.timer[N].delaylist = intervals","intervals","Table of delay intervals in seconds","N","Trigger timer number (1 to 8)","Details","Each time the timer is triggered after it is enabled, it uses the next delay period from the array. The default value is an array with one value of 10 µs.","After all elements in the array have been used, the delays restart at the beginning of the list.","If the array contains more than one element, the average of the delay intervals in the list must be ³ 50 µs.","Example","trigger.timer[3].delaylist = {50e-6, 100e-6, 150e-6}","DelayList = trigger.timer[3].delaylist","for x = 1, table.getn(DelayList) do"," print(DelayList[x])","end","Set a delay list on trigger timer 3 with three delays (50 µs, 100 µs, and 150 µs).","Read the delay list on trigger timer 3.","Output:","5e-05","0.0001","0.00015","Also see","trigger.timer[N].reset()","trigger.timer[N].delaylist","15795.htm"); +Page[441]=new Array("This constant specifies the trigger timer event number.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = trigger.timer[N].EVENT_ID","eventID","The trigger event number","N","Trigger timer number (1 to 8)","Details","This constant is an identification number that identifies events generated by this timer.","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to events from this timer.","Example","trigger.timer[1].stimulus = tsplink.trigger[2].EVENT_ID","Sets the trigger stimulus of trigger timer 1 to the TSP-Link trigger 2 event.","Also see","None","trigger.timer[N].EVENT_ID","15796.htm"); +Page[442]=new Array("This attribute indicates if an event was ignored because of the event detector state.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Instrument reset
Recall setup
Trigger timer N clear
Trigger timer N reset","Not applicable","false","Usage","overrun = trigger.timer[N].overrun","overrun","Trigger overrun state (true or false)","N","Trigger timer number (1 to 8)","Details","This command indicates if an event was ignored because the event detector was already in the detected state when the event occurred.","This is an indication of the state of the event detector built into the timer itself. It does not indicate if an overrun occurred in any other part of the trigger model or in any other construct that is monitoring the delay completion event. It also is not an indication of a delay overrun.","Delay overrun indications are provided in the status model.","Example","print(trigger.timer[1].overrun)","If an event was ignored, the output is true.","If the event was not ignored, the output is false.","Also see","trigger.timer[N].reset()","trigger.timer[N].overrun","15797.htm"); +Page[443]=new Array("This attribute enables or disables the timer trigger pass‑through mode.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup
Trigger timer N reset","Not saved ","false (disabled)","Usage","passthrough = trigger.timer[N].passthrough","trigger.timer[N].passthrough = passthrough","passthrough","The state of pass-through mode; set to one of the following values:","true: Enabled","false: Disabled","N","Trigger timer number (1 to 8)","Details","When pass-through mode is enabled, triggers are passed through immediately and initiate the delay. When disabled, a trigger only initiates a delay.","Example","trigger.timer[1].passthrough = true","Enables pass‑through mode on trigger timer 1.","Also see","trigger.timer[N].reset()","trigger.timer[N].passthrough","15798.htm"); +Page[444]=new Array("This function resets some of the trigger timer settings to their factory defaults.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","trigger.timer[N].reset()","N","Trigger timer number (1 to 8)","Details","The trigger.timer[N].reset() function resets the following attributes to their factory defaults:","trigger.timer[N].count","trigger.timer[N].delay","trigger.timer[N].delaylist","trigger.timer[N].passthrough","trigger.timer[N].stimulus","It also clears trigger.timer[N].overrun.","Example","trigger.timer[1].reset()","Resets the attributes associated with timer 1 back to factory default values.","Also see","trigger.timer[N].count","trigger.timer[N].delay","trigger.timer[N].delaylist","trigger.timer[N].overrun","trigger.timer[N].passthrough","trigger.timer[N].stimulus","trigger.timer[N].reset()","17668.htm"); +Page[445]=new Array("This attribute specifies which event starts the timer.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup
Trigger timer N reset","Not saved","0","Usage","eventID = trigger.timer[N].stimulus","trigger.timer[N].stimulus = eventID","eventID","The event that triggers the timer delay","N","Trigger timer number (1 to 8)","Details","The eventID parameter may be one of the trigger event IDs shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Set this attribute to the eventID of any trigger event to cause the timer to start when that event occurs.","Set this attribute to zero (0) to disable event processing.","Example","print(trigger.timer[1].stimulus)","Prints the event that will start a trigger 1 timer action.","Also see","trigger.timer[N].reset()","trigger.timer[N].stimulus","17688.htm"); +Page[446]=new Array("This function waits for a trigger.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","triggered = trigger.timer[N].wait(timeout)","triggered","Trigger detection indication","N","Trigger timer number (1 to 8)","timeout","Maximum amount of time in seconds to wait for the trigger","Details","If one or more trigger events were detected since the last time trigger.timer[N].wait() or trigger.timer[N].clear() was called, this function returns immediately.","After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.","Example","triggered = trigger.timer[3].wait(10)","print(triggered)","Waits up to 10 s for a trigger on timer 3.","If false is returned, no trigger was detected during the 10 s timeout.","If true is returned, a trigger was detected.","Also see","trigger.timer[N].clear()","trigger.timer[N].wait()","15800.htm"); +Page[447]=new Array("This function waits for a command interface trigger event.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","triggered = trigger.wait(timeout)","triggered","true: A trigger was detected during the timeout period","false: No triggers were detected during the timeout period","timeout","Maximum amount of time in seconds to wait for the trigger","Details","This function waits up to timeout seconds for a trigger on the active command interface. A command interface trigger occurs when:","A GPIB GET command is detected (GPIB only)","A USBTMC TRIGGER message is received (USB only)","A VXI-11 device_trigger method is invoked (VXI-11 only)","A *TRG message is received","If one or more of these trigger events were previously detected, this function returns immediately.","After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.","Example","triggered = trigger.wait(10)","print(triggered)","Waits up to 10 seconds for a trigger.","If false is returned, no trigger was detected during the 10‑second timeout.","If true is returned, a trigger was detected.","Also see","trigger.clear()","trigger.wait()","15801.htm"); +Page[448]=new Array("This attribute contains the group number of a TSP‑Link node. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Power cycle","Not applicable","0","Usage","groupNumber = tsplink.group","tsplink.group = groupNumber","groupNumber","The group number of the TSP-Link node (0 to 64)","Details","To remove the node from all groups, set the attribute value to 0.","When the node is turned off, the group number for that node changes to 0.","The master node can be assigned to any group. You can also include other nodes in the group that includes the master. Note that any nodes that are set to 0 are automatically included in the group that contains the master node, regardless of the group that is assigned to the master node.","Example","tsplink.group = 3","Assign the instrument to TSP-Link group number 3.","Also see","Using groups to manage nodes on a TSP-Link system","tsplink.group","15285.htm"); +Page[449]=new Array("This attribute reads the node number assigned to the master node. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","masterNodeNumber = tsplink.master","masterNodeNumber","The node number of the master node","Details","After doing a TSP-Link reset (tsplink.reset()), use this attribute to access the node number of the master in a set of instruments connected over TSP-Link.","Example","LinkMaster = tsplink.master","Store the TSP-Link master node number in a variable called LinkMaster.","Also see","tsplink.reset()","tsplink.master","15286.htm"); +Page[450]=new Array("This attribute defines the node number. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Not applicable","Nonvolatile memory","1","Usage","nodeNumber = tsplink.node","tsplink.node = nodeNumber","nodeNumber","The node number of the instrument or enclosure (1 to 64 )","Details","This command sets the TSP‑Link node number and saves the value in nonvolatile memory.","Changes to the node number do not take effect until tsplink.reset() from an earlier TSP‑Link instrument is executed on any node in the system.","Each node connected to the TSP-Link system must be assigned a different node number.","Example","tsplink.node = 3","Sets the TSP‑Link node for this instrument to number 3.","Also see","tsplink.reset()","tsplink.state","tsplink.node","15287.htm"); +Page[451]=new Array("This function reads the state of a TSP-Link synchronization line. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","data = tsplink.readbit(N)","data","The state of the synchronization line","N","The trigger line (1 to 3)","Details","Returns a value of zero (0) if the line is low and 1 if the line is high.","Example","data = tsplink.readbit(3)","print(data)","Assume line 3 is set high, and it is then read.","Output:","1.000000e+00","Also see","tsplink.readport()","tsplink.writebit()","tsplink.readbit()","15288.htm"); +Page[452]=new Array("This function reads the TSP-Link trigger lines as a digital I/O port. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","data = tsplink.readport()","data","Numeric value that indicates which lines are set","Details","The binary equivalent of the returned value indicates the input pattern on the I/O port. The least significant bit of the binary number corresponds to line 1 and the value of bit 3 corresponds to line 3. For example, a returned value of 2 has a binary equivalent of 010. This indicates that line 2 is high (1), and that the other two lines are low (0).","Example","data = tsplink.readport()","print(data)","Reads state of all three TSP-Link lines.","Assuming line 2 is set high, the output is:","2.000000e+00","(binary 010)","The format of the output may vary depending on the ASCII precision setting.","Also see","TSP-Link trigger lines","tsplink.readbit()","tsplink.writebit() ","tsplink.writeport()","tsplink.readport()","15289.htm"); +Page[453]=new Array("This function initializes (resets) all nodes (instruments) in the TSP‑Link system. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","nodesFound = tsplink.reset()","nodesFound = tsplink.reset(expectedNodes)","nodesFound","The number of nodes actually found on the system","expectedNodes","The number of nodes expected on the system (1 to 64)","Details","This function erases all information regarding other nodes connected on the TSP-Link system and regenerates the system configuration. This function must be called at least once before any remote nodes can be accessed. If the node number for any instrument is changed, the TSP-Link must be reset again.","If expectedNodes is not given, this function generates an error if no other nodes are found on the TSP‑Link network.","If nodesFound is less than expectedNodes, an error is generated. Note that the node on which the command is running is counted as a node. For example, giving an expected node count of 1 will not generate any errors, even if there are no other nodes on the TSP-Link network.","Also returns the number of nodes found.","Example","nodesFound = tsplink.reset(2)","print("Nodes found = " .. nodesFound)","Perform a TSP-Link reset and indicate how many nodes are found.","Sample output if two nodes are found:
Nodes found = 2","Sample output if fewer nodes are found and if localnode.showerrors = 1:
1219, TSP-Link found fewer nodes
than expected
Nodes found = 1","Also see","localnode.showerrors","tsplink.node","tsplink.state","tsplink.reset()","15290.htm"); +Page[454]=new Array("This attribute describes the TSP‑Link online state. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Not applicable","Not applicable","Not applicable","Usage","state = tsplink.state","state","TSP-Link state (online or offline)","Details","When the instrument power is first turned on, the state is offline. After tsplink.reset() is successful, the state is online.","Example","state = tsplink.state","print(state)","Read the state of the TSP‑Link system. If it is online, the output is:","online","Also see","tsplink.node","tsplink.reset()","tsplink.state","15291.htm"); +Page[455]=new Array("This function simulates the occurrence of the trigger and generates the corresponding event ID. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","tsplink.trigger[N].assert()","N","The trigger line (1 to 3)","Details","The set pulse width determines how long the trigger is asserted.","Example","tsplink.trigger[2].assert()","Asserts trigger on trigger line 2.","Also see","tsplink.trigger[N].clear()","tsplink.trigger[N].mode","tsplink.trigger[N].overrun","tsplink.trigger[N].pulsewidth","tsplink.trigger[N].release()","tsplink.trigger[N].stimulus","tsplink.trigger[N].wait()","tsplink.trigger[N].assert()","15292.htm"); +Page[456]=new Array("This function clears the event detector for a LAN trigger. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","tsplink.trigger[N].clear()","N","The trigger line (1 to 3) to clear","Details","The trigger event detector enters the detected state when an event is detected. tsplink.trigger[N].clear() clears a trigger event detector, discards the history of the trigger line, and clears the tsplink.trigger[N].overrun attribute.","Example","tsplink.trigger[2].clear()","Clears trigger event on synchronization line 2.","Also see","tsplink.trigger[N].mode","tsplink.trigger[N].overrun","tsplink.trigger[N].release()","tsplink.trigger[N].stimulus","tsplink.trigger[N].wait()","tsplink.trigger[N].clear()","15293.htm"); +Page[457]=new Array("This constant identifies the number that is used for the trigger events. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Constant","Yes","Usage","eventID = tsplink.trigger[N].EVENT_ID","eventID","The trigger event number","N","The trigger line (1 to 3)","Details","This number is used by the TSP-Link trigger line when it detects an input trigger.","Set the stimulus of any trigger object to the value of this constant to have the trigger object respond to trigger events from this line.","Example","trigger.timer[1].stimulus = tsplink.trigger[2].EVENT_ID","Sets the trigger stimulus of trigger timer 1 to the TSP-Link trigger 2 event.","Also see","None","tsplink.trigger[N].EVENT_ID","15294.htm"); +Page[458]=new Array("This attribute defines the trigger operation and detection mode. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup
TSP-Link trigger N reset","Not saved","0 (tsplink.TRIG_BYPASS)","Usage","mode = tsplink.trigger[N].mode","tsplink.trigger[N].mode = mode","mode","The trigger mode","N","The trigger line (1 to 3)","Details","This attribute controls the mode in which the trigger event detector and the output trigger generator operate on the given trigger line.","The setting for mode can be one of the following values:","Mode","Number value","Description","tsplink.TRIG_BYPASS","0","Allows direct control of the line as a digital I/O line.","tsplink.TRIG_FALLING","1","Detects falling‑edge triggers as input. Asserts a TTL-low pulse for output.","tsplink.TRIG_RISING","2","If the programmed state of the line is high, the tsplink.TRIG_RISING mode behaves similarly to tsplink.TRIG_RISINGA.","If the programmed state of the line is low, the tsplink.TRIG_RISING mode behaves similarly to tsplink.TRIG_RISINGM.","Use tsplink.TRIG_RISINGA if the line is in the high output state.","Use tsplink.TRIG_RISINGM if the line is in the low output state.","tsplink.TRIG_EITHER","3","Detects rising‑ or falling‑edge triggers as input. Asserts a TTL‑low pulse for output.","tsplink.TRIG_SYNCHRONOUSA","4","Detects the falling‑edge input triggers and automatically latches and drives the trigger line low.","tsplink.TRIG_SYNCHRONOUS","5","Detects the falling‑edge input triggers and automatically latches and drives the trigger line low. Asserts a TTL-low pulse as an output trigger.","tsplink.TRIG_SYNCHRONOUSM","6","Detects rising‑edge triggers as an input. Asserts a TTL‑low pulse for output.","tsplink.TRIG_RISINGA","7","Detects rising‑edge triggers as input. Asserts a TTL‑low pulse for output.","tsplink.TRIG_RISINGM","8","Edge detection as an input is not available. Generates a TTL‑high pulse as an output trigger.","When programmed to any mode except tsplink.TRIG_BYPASS, the output state of the I/O line is controlled by the trigger logic, and the user-specified output state of the line is ignored.","When the trigger mode is set to tsplink.TRIG_RISING, the user‑specified output state of the line is examined. If the output state selected when the mode is changed is high, the actual mode used will be tsplink.TRIG_RISINGA. If the output state selected when the mode is changed is low, the actual mode used will be tsplink.TRIG_RISINGM.","mode stores the trigger mode as a numeric value when the attribute is read.","To control the line state, use the tsplink.TRIG_BYPASS mode with the tsplink.writebit() and the tsplink.writeport() commands.","Example","tsplink.trigger[3].mode = tsplink.TRIG_RISINGM","Sets the trigger mode for synchronization line 3 to tsplink.TRIG_RISINGM.","Also see","digio.writebit()","digio.writeport()","tsplink.trigger[N].assert()","tsplink.trigger[N].clear()","tsplink.trigger[N].overrun","tsplink.trigger[N].release()","tsplink.trigger[N].reset()","tsplink.trigger[N].stimulus","tsplink.trigger[N].wait()","tsplink.trigger[N].mode","15295.htm"); +Page[459]=new Array("This attribute indicates if the event detector ignored an event while in the detected state. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (R)","Yes","Instrument reset
Recall setup
TSP-Link trigger N clear
TSP-Link trigger N reset","Not applicable","Not applicable","Usage","overrun = tsplink.trigger[N].overrun","overrun","Trigger overrun state","N","The trigger line (1 to 3)","Details","This command indicates whether an event has been ignored because the event detector was already in the detected state when the event occurred.","This is an indication of the state of the event detector built into the synchronization line itself.","It does not indicate if an overrun occurred in any other part of the trigger model, or in any other construct that is monitoring the event. It also is not an indication of an output trigger overrun. Output trigger overrun indications are provided in the status model.","Example","print(tsplink.trigger[1].overrun)","If an event was ignored, displays true; if an event was not ignored, displays false.","Also see","tsplink.trigger[N].assert()","tsplink.trigger[N].clear()","tsplink.trigger[N].mode","tsplink.trigger[N].release()","tsplink.trigger[N].reset()","tsplink.trigger[N].stimulus","tsplink.trigger[N].wait()","tsplink.trigger[N].overrun","15296.htm"); +Page[460]=new Array("This attribute sets the length of time that the trigger line is asserted for output triggers. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
TSP-Link trigger N reset
Recall setup","Not saved","10e-6 (10 µs)","Usage","width = tsplink.trigger[N].pulsewidth","tsplink.trigger[N].pulsewidth = width","width","The pulse width (in seconds)","N","The trigger line (1 to 3)","Details","Setting the pulse width to 0 (seconds) asserts the trigger indefinitely.","Example","tsplink.trigger[3].pulsewidth = 20e-6","Sets pulse width for trigger line 3 to 20 μs.","Also see","tsplink.trigger[N].release()","tsplink.trigger[N].pulsewidth","15297.htm"); +Page[461]=new Array("This function releases a latched trigger on the given TSP‑Link trigger line. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","tsplink.trigger[N].release()","N","The trigger line (1 to 3)","Details","Releases a trigger that was asserted with an indefinite pulse width. It also releases a trigger that was latched in response to receiving a synchronous mode trigger.","Example","tsplink.trigger[3].release()","Releases trigger line 3.","Also see","tsplink.trigger[N].assert()","tsplink.trigger[N].clear()","tsplink.trigger[N].mode","tsplink.trigger[N].overrun","tsplink.trigger[N].pulsewidth","tsplink.trigger[N].stimulus","tsplink.trigger[N].wait()","tsplink.trigger[N].release()","15298.htm"); +Page[462]=new Array("This function resets some of the TSP-Link trigger attributes to their factory defaults. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","tsplink.trigger[N].reset()","N","The trigger line (1 to 3)","Details","The tsplink.trigger[N].reset() function resets the following attributes to their factory defaults:","tsplink.trigger[N].mode","tsplink.trigger[N].stimulus","tsplink.trigger[N].pulsewidth","This also clears tsplink.trigger[N].overrun.","Example","tsplink.trigger[3].reset()","Resets TSP-Link trigger line 3 attributes back to factory default values.","Also see","tsplink.trigger[N].mode","tsplink.trigger[N].overrun","tsplink.trigger[N].pulsewidth","tsplink.trigger[N].stimulus","tsplink.trigger[N].reset()","17669.htm"); +Page[463]=new Array("This attribute specifies the event that causes the synchronization line to assert a trigger. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup
TSP-Link trigger N reset","Not saved","0","Usage","eventID = tsplink.trigger[N].stimulus","tsplink.trigger[N].stimulus = eventID","eventID","The event identifier for the triggering event","N","The trigger line (1 to 3)","Details","To disable automatic trigger assertion on the synchronization line, set this attribute to zero (0).","Do not use this attribute when triggering under script control. Use tsplink.trigger[N].assert() instead.","The eventID parameter may be one of the existing trigger event IDs shown in the following table.","Trigger event IDs*","Event ID","Event description","smua.trigger.SWEEPING_EVENT_ID","Occurs when the source‑measure unit (SMU) transitions from the idle state to the arm layer of the trigger model","smua.trigger.ARMED_EVENT_ID","Occurs when the SMU moves from the arm layer to the trigger layer of the trigger model","smua.trigger.SOURCE_COMPLETE_EVENT_ID","Occurs when the SMU completes a source action","smua.trigger.MEASURE_COMPLETE_EVENT_ID","Occurs when the SMU completes a measurement action","smua.trigger.PULSE_COMPLETE_EVENT_ID","Occurs when the SMU completes a pulse","smua.trigger.SWEEP_COMPLETE_EVENT_ID","Occurs when the SMU completes a sweep","smua.trigger.IDLE_EVENT_ID","Occurs when the SMU returns to the idle state","digio.trigger[N].EVENT_ID","Occurs when an edge is detected on a digital I/O line","tsplink.trigger[N].EVENT_ID","Occurs when an edge is detected on a TSP‑Link line","lan.trigger[N].EVENT_ID","Occurs when the appropriate LXI trigger packet is received on LAN trigger object N","display.trigger.EVENT_ID","Occurs when the TRIG key on the front panel is pressed","trigger.EVENT_ID","Occurs when a *TRG command is received on the remote interface","GPIB only: Occurs when a GET bus command is received","USB only: Occurs when a USBTMC TRIGGER message is received","VXI-11 only: Occurs with the VXI-11 command device_trigger; reference the VXI-11 standard for additional details on the device trigger operation","trigger.blender[N].EVENT_ID","Occurs after a collection of events is detected","trigger.timer[N].EVENT_ID","Occurs when a delay expires","trigger.generator[N].EVENT_ID","Occurs when the trigger.generator[N].assert() function is executed","* Use the name of the trigger event ID to set the stimulus value rather than the numeric value. Using the name makes the code compatible for future upgrades (for example, if the numeric values must change when enhancements are added to the instrument).","Example","print(tsplink.trigger[3].stimulus)","Prints the event that will start TSP-Link trigger line 3 action.","Also see","tsplink.trigger[N].assert()","tsplink.trigger[N].reset()","tsplink.trigger[N].stimulus","17682.htm"); +Page[464]=new Array("This function waits for a trigger. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","triggered = tsplink.trigger[N].wait(timeout)","triggered","Trigger detection indication; set to one of the following values:","true: A trigger is detected during the timeout period","false: A trigger is not detected during the timeout period","N","The trigger line (1 to 3)","timeout","The timeout value in seconds","Details","This function waits up to the timeout value for an input trigger. If one or more trigger events were detected since the last time tsplink.trigger[N].wait() or tsplink.trigger[N].clear() was called, this function returns immediately.","After waiting for a trigger with this function, the event detector is automatically reset and rearmed. This is true regardless of the number of events detected.","Example","triggered = tsplink.trigger[3].wait(10)","print(triggered)","Waits up to 10 seconds for a trigger on TSP-Link® line 3.","If false is returned, no trigger was detected during the 10-second timeout.","If true is returned, a trigger was detected.","Also see","tsplink.trigger[N].clear()","tsplink.trigger[N].wait()","15300.htm"); +Page[465]=new Array("This function sets a TSP-Link trigger line high or low. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","tsplink.writebit(N, data)","N","The trigger line (1 to 3)","data","The value to write to the bit:","Low: 0","High: 1","Details","Use tsplink.writebit() and tsplink.writeport() to control the output state of the trigger line when trigger operation is set to tsplink.TRIG_BYPASS.","If the output line is write‑protected by the tsplink.writeprotect attribute, this command is ignored.","The reset function does not affect the present states of the TSP-Link trigger lines.","Example","tsplink.writebit(3, 0)","Sets trigger line 3 low (0).","Also see","tsplink.readbit()","tsplink.readport()","tsplink.writeport()","tsplink.writeprotect","tsplink.writebit()","15301.htm"); +Page[466]=new Array("This function writes to all TSP‑Link synchronization lines. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","tsplink.writeport(data)","data","Value to write to the port (0 to 7)","Details","The binary representation of data indicates the output pattern that is written to the I/O port. For example, a data value of 2 has a binary equivalent of 010. Line 2 is set high (1), and the other two lines are set low (0).","Write‑protected lines are not changed.","Use the tsplink.writebit() and tsplink.writeport() commands to control the output state of the synchronization line when trigger operation is set to tsplink.TRIG_BYPASS.","The reset() function does not affect the present states of the trigger lines.","Example","tsplink.writeport(3)","Sets the synchronization lines 1 and 2 high (binary 011).","Also see","tsplink.readbit()","tsplink.readport()","tsplink.writebit()","tsplink.writeprotect","tsplink.writeport()","15302.htm"); +Page[467]=new Array("This attribute contains the write‑protect mask that protects bits from changes by the tsplink.writebit() and tsplink.writeport() functions. ","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","Yes","Instrument reset
Recall setup","Saved setup","0","Usage","mask = tsplink.writeprotect","tsplink.writeprotect = mask","mask","An integer that specifies the value of the bit pattern for write‑protect; set bits to 1 to write‑protect the corresponding TSP-Link trigger line","Details","The binary equivalent of mask indicates the mask to be set for the TSP-Link trigger line. For example, a mask value of 5 has a binary equivalent of 101. This mask write‑protects TSP-Link trigger lines 1 and 3.","Example","tsplink.writeprotect = 5","Write‑protects TSP-Link trigger lines 1 and 3.","Also see","Controlling digital I/O lines","tsplink.readbit()","tsplink.readport()","tsplink.writebit()","tsplink.writeport()","tsplink.writeprotect","17630.htm"); +Page[468]=new Array("This function clears any pending output data from the instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","tspnet.clear(connectionID)","connectionID","The connection ID returned from tspnet.connect()","Details","This function clears any pending output data from the device. No data is returned to the caller and no data is processed.","Example","tspnet.write(testdevice, "print([[hello]])")","print(tspnet.readavailable(testdevice))","tspnet.clear(testdevice)","print(tspnet.readavailable(testdevice))","Write data to a device, then print how much is available.","Output:","6.00000e+00","Clear data and print how much data is available again.","Output:","0.00000e+00","Also see","tspnet.connect()","tspnet.readavailable()","tspnet.write()","tspnet.clear()","14073.htm"); +Page[469]=new Array("This function establishes a network connection with another LAN instrument or device through the LAN interface.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","connectionID = tspnet.connect("ipAddress")","connectionID = tspnet.connect("ipAddress", portNumber, "initString")","connectionID","The connection ID to be used as a handle in all other tspnet function calls","ipAddress","IP address to which to connect in a string","portNumber","Port number (default 5025)","initString","Initialization string to send to ipAddress","Details","This command connects a device to another device through the LAN interface. If the portNumber is 23, the interface uses the Telnet protocol and sets appropriate termination characters to communicate with the device.","If a portNumber and initString are provided, it is assumed that the remote device is not TSP‑enabled. The 2601B-PULSE does not perform any extra processing, prompt handling, error handling, or sending of commands. In addition, the tspnet.tsp.* commands cannot be used on devices that are not TSP‑enabled.","If neither a portNumber nor an initString is provided, the remote device is assumed to be a Keithley Instruments TSP‑enabled device. Depending on the state of the tspnet.tsp.abortonconnect attribute, the 2601B-PULSE sends an abort command to the remote device on connection. ","The 2601B-PULSE also enables TSP prompts on the remote device and error management. The 2601B-PULSE places remote errors from the TSP‑enabled device in its own error queue and prefaces these errors with Remote Error, followed by an error description. ","Do not manually change either the prompt functionality (localnode.prompts) or show errors by changing localnode.showerrors on the remote TSP-enabled device. If you do this, subsequent tspnet.tsp.* commands using the connection may fail.","You can simultaneously connect to a maximum of 32 remote devices.","Example 1","instrumentID = tspnet.connect("192.0.2.1")","if instrumentID then"," -- Use instrumentID as needed here"," tspnet.disconnect(instrumentID)","end","Connect to a TSP-enabled device.","Example 2","instrumentID = tspnet.connect("192.0.2.1", 1394, "*rst\\r\\n")","if instrumentID then"," -- Use instrumentID as needed here"," tspnet.disconnect(instrumentID)","end","Connect to a device that is not TSP‑enabled.","Also see","localnode.prompts","localnode.showerrors","tspnet.tsp.abortonconnect","tspnet.disconnect()","tspnet.connect()","14074.htm"); +Page[470]=new Array("This function disconnects a specified TSP-Net session.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","tspnet.disconnect(connectionID)","connectionID","The connection ID returned from tspnet.connect()","Details","This function disconnects the two devices by closing the connection. The connectionID is the session handle returned by tspnet.connect().","For TSP-enabled devices, this aborts any remotely running commands or scripts.","Example","testID = tspnet.connect("192.0.2.0")","-- Use the connection","tspnet.disconnect(testID)","Create a TSP‑Net session.","Close the session.","Also see","tspnet.connect()","tspnet.disconnect()","14076.htm"); +Page[471]=new Array("This function sends a command string to the remote device.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","tspnet.execute("connectionID", "commandString")","value1 = tspnet.execute("connectionID", "commandString", formatString)","value1, value2 = tspnet.execute("connectionID", "commandString", formatString)","value1, ..., valueN = tspnet.execute("connectionID", "commandString", formatString)","connectionID","The connection ID returned from tspnet.connect()","commandString","The command to send to the remote device","value1","The first value decoded from the response message","value2","The second value decoded from the response message","valueN","The Nth value decoded from the response message; there is one return value for each format specifier in the format string","...","One or more values separated with commas","formatString","Format string for the output","Details","This command sends a command string to the remote instrument. A termination is added to the command string when it is sent to the remote instrument (tspnet.termination()). You can also specify a format string, which causes the command to wait for a response from the remote instrument. The 2601B-PULSE decodes the response message according to the format specified in the format string and returns the message as return values from the function (see tspnet.read() for format specifiers).","When this command is sent to a TSP-enabled instrument, the 2601B-PULSE suspends operation until a timeout error is generated or until the instrument responds. The TSP prompt from the remote instrument is read and discarded. The 2601B-PULSE places any remotely generated errors into its error queue. When the optional format string is not specified, this command is equivalent to tspnet.write(), except that a termination is automatically added to the end of the command.","Example 1","tspnet.execute(instrumentID, "runScript()")","Command the remote device to run a script named runScript.","Example 2","tspnet.timeout = 5","id_instr = tspnet.connect("192.0.2.23", 23, "*rst\\r\\n")","tspnet.termination(id_instr, tspnet.TERM_CRLF)","tspnet.execute(id_instr, "*idn?")","print("tspnet.execute returns:", tspnet.read(id_instr))","Print the *idn? string from the remote device.","Also see","tspnet.connect()","tspnet.read()","tspnet.termination()","tspnet.write()","tspnet.execute()","14077.htm"); +Page[472]=new Array("This function retrieves the response of the remote device to *IDN?.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","idnString = tspnet.idn(connectionID)","idnString","The returned *IDN? string","connectionID","The connection ID returned from tspnet.connect()","Details","This function retrieves the response of the remote device to *IDN?.","Example","deviceID = tspnet.connect("192.0.2.1")","print(tspnet.idn(deviceID))","tspnet.disconnect(deviceID)","Assume the instrument is at IP address 192.0.2.1.","The output that is produced when you connect to the instrument and read the identification string may appear as:","Keithley Instruments,Model 2601B-PULSE, 1398687, 1.0.0","Also see","tspnet.connect()","tspnet.idn()","14078.htm"); +Page[473]=new Array("This function reads data from a remote device.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","value1 = tspnet.read(connectionID)","value1 = tspnet.read(connectionID, formatString)","value1, value2 = tspnet.read(connectionID, formatString)","value1, ..., valueN = tspnet.read(connectionID, formatString)","value1","The first value decoded from the response message","value2","The second value decoded from the response message","valueN","The nth value decoded from the response message; there is one return value for each format specifier in the format string","...","One or more values separated with commas","connectionID","The connection ID returned from tspnet.connect()","formatString","Format string for the output, maximum of 10 specifiers","Details","This command reads available data from the remote instrument and returns responses for the specified number of arguments.","The format string can contain the following specifiers:","%[width]s","Read data until the specified length","%[max width]t","Read data until the specified length or until punctuation is found, whichever comes first","%[max width]n","Read data until a newline or carriage return","%d","Read a number (delimited by punctuation)","A maximum of 10 format specifiers can be used for a maximum of 10 return values.","If formatString is not provided, the command returns a string that contains the data until a new line is reached. If no data is available, the 2601B-PULSE pauses operation until the requested data is available or until a timeout error is generated. Use tspnet.timeout to specify the timeout period.","When the 2601B-PULSE reads from a TSP-enabled remote instrument, the 2601B-PULSE removes Test Script Processor (TSP®) prompts and places any errors it receives from the remote instrument into its own error queue. The 2601B-PULSE prefaces errors from the remote device with "Remote Error," followed by the error number and error description.","Example","tspnet.write(deviceID, "*idn?\\r\\n")","print("write/read returns:", tspnet.read(deviceID))","Send the "*idn?\\r\\n" message to the instrument connected as deviceID.","Display the response that is read from deviceID (based on the *idn? message).","Also see","tspnet.connect()","tspnet.readavailable()","tspnet.timeout","tspnet.write()","tspnet.read()","14079.htm"); +Page[474]=new Array("This function checks to see if data is available from the remote device.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","bytesAvailable = tspnet.readavailable(connectionID)","bytesAvailable","The number of bytes available to be read from the connection","connectionID","The connection ID returned from tspnet.connect()","Details","This command checks to see if any output data is available from the device. No data is read from the instrument. This allows TSP scripts to continue to run without waiting on a remote command to finish.","Example","ID = tspnet.connect("192.0.2.1")","tspnet.write(ID, "*idn?\\r\\n")","repeat bytes = tspnet.readavailable(ID) until bytes > 0","print(tspnet.read(ID))","tspnet.disconnect(ID)","Send commands that will create data.","Wait for data to be available.","Also see","tspnet.connect()","tspnet.read()","tspnet.readavailable()","14080.htm"); +Page[475]=new Array("This function disconnects all TSP-Net sessions.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","tspnet.reset()","Details","This command disconnects all remote instruments connected through TSP-Net. For TSP-enabled devices, this causes any commands or scripts running remotely to be terminated.","Also see","None","tspnet.reset()","14081.htm"); +Page[476]=new Array("This function sets the device line termination sequence.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","type = tspnet.termination(connectionID)","type = tspnet.termination(connectionID, termSequence)","type","An enumerated value indicating the termination type:","1 or tspnet.TERM_LF","4 or tspnet.TERM_CR","2 or tspnet.TERM_CRLF","3 or tspnet.TERM_LFCR","connectionID","The connection ID returned from tspnet.connect()","termSequence","The termination sequence","Details","This function sets and gets the termination character sequence that is used to indicate the end of a line for a TSP-Net connection.","Using the termSequence parameter sets the termination sequence. The present termination sequence is always returned.","For the termSequence parameter, use the same values listed in the table above for type. There are four possible combinations, all of which are made up of line feeds (LF or 0x10) and carriage returns (CR or 0x13). For TSP-enabled devices, the default is tspnet.TERM_LF. For devices that are not TSP‑enabled, the default is tspnet.TERM_CRLF.","Example","deviceID = tspnet.connect("192.0.2.1")","if deviceID then"," tspnet.termination(deviceID, tspnet.TERM_LF)","end","Sets termination type for IP address 192.0.2.1 to TERM_LF.","Also see","tspnet.connect()","tspnet.disconnect()","tspnet.termination()","14082.htm"); +Page[477]=new Array("This attribute sets the timeout value for the tspnet.connect(), tspnet.execute(), and tspnet.read() commands.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","No","Instrument reset
Recall setup","Not saved","20.0 (20 s)"," ","Usage","value = tspnet.timeout","tspnet.timeout = value","value","The timeout duration in seconds (1 ms to 30.0 s)","Details","This attribute sets the amount of time the tspnet.connect(), tspnet.execute(), and tspnet.read() commands will wait for a response.","The time is specified in seconds. The timeout may be specified to millisecond resolution but is only accurate to the nearest 10 ms.","Example","tspnet.timeout = 2.0","Sets the timeout duration to 2 s.","Also see","tspnet.connect()","tspnet.execute()","tspnet.read()","tspnet.timeout","14084.htm"); +Page[478]=new Array("This function causes the TSP-enabled instrument to stop executing any of the commands that were sent to it.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","tspnet.tsp.abort(connectionID)","connectionID","Integer value used as a handle for other tspnet commands","Details","This function is appropriate only for TSP-enabled instruments.","Sends an abort command to the remote instrument.","Example","tspnet.tsp.abort(testConnection)","Stops remote instrument execution on testConnection.","Also see","None","tspnet.tsp.abort()","14085.htm"); +Page[479]=new Array("This attribute contains the setting for abort on connect to a TSP-enabled instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Attribute (RW)","No","Instrument reset
Recall setup","Not saved","1 (enable)","Usage","tspnet.tsp.abortonconnect = value","value = tspnet.tsp.abortonconnect","value","Enable: 1","Disable: 0","Details","This setting determines if the instrument sends an abort message when it attempts to connect to a TSP‑enabled instrument using the tspnet.connect() function.","When you send the abort command on an interface, it causes any other active interface on that instrument to close. If you do not send an abort command (or if tspnet.tsp.abortonconnect is set to 0) and another interface is active, connecting to a TSP‑enabled remote instrument results in a connection. However, the instrument will not respond to subsequent reads or executes because control of the instrument is not obtained until an abort command has been sent.","Example","tspnet.tsp.abortonconnect = 0","Configure the instrument so that it does not send an abort command when connecting to a TSP‑enabled instrument.","Also see","tspnet.connect()","tspnet.tsp.abortonconnect","14086.htm"); +Page[480]=new Array("This function copies a reading buffer synchronous table from a remote instrument to a TSP-enabled instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","table = tspnet.tsp.rbtablecopy(connectionID, "name")","table = tspnet.tsp.rbtablecopy(connectionID, "name", startIndex, endIndex)","table","A copy of the synchronous table or a string","connectionID","Integer value used as a handle for other tspnet commands","name","The full name of the reading buffer name and synchronous table to copy","startIndex","Integer start value","endIndex","Integer end value","Details","This function is only appropriate for TSP-enabled instruments.","This function reads the data from a reading buffer on a remote instrument and returns an array of numbers or a string representing the data. The startIndex and endIndex parameters specify the portion of the reading buffer to read. If no index is specified, the entire buffer is copied. ","The function returns a table if the table is an array of numbers; otherwise a comma‑delimited string is returned.","This command is limited to transferring 50,000 readings at a time.","Example","t = tspnet.tsp.rbtablecopy(testConnection,"," "testRemotebuffername.readings", 1, 3)","print(t[1], t[2], t[3])","Copy the specified readings table for buffer items 1 through 3, then display the first three readings. Example output:","4.56534e-01","4.52675e-01","4.57535e-01","Also see","None","tspnet.tsp.rbtablecopy()","14090.htm"); +Page[481]=new Array("This function loads and runs a script on a remote TSP-enabled instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","Yes","Usage","tspnet.tsp.runscript(connectionID, "script")","tspnet.tsp.runscript(connectionID, "name", "script")","connectionID","Integer value used as an identifier for other tspnet commands","name","The name that is assigned to the script","script","The body of the script as a string","Details","This function is appropriate only for TSP-enabled instruments.","This function downloads a script to a remote instrument and runs it. It automatically adds the appropriate loadscript and endscript commands around the script, captures any errors, and reads back any prompts. No additional substitutions are done on the text.","The script is automatically loaded, compiled, and run.","Any output from previous commands is discarded.","This command does not wait for the script to complete.","If you do not want the script to do anything immediately, make sure the script only defines functions for later use. Use the tspnet.execute() function to execute those functions later.","If no name is specified, the script is loaded as the anonymous script.","Example","tspnet.tsp.runscript(myconnection, "mytest",",""print([[start]]) for d = 1, 10 do print([[work]]) end print([[end]])")","Load and run a script entitled mytest on the TSP‑enabled instrument connected with myconnection.","Also see","tspnet.execute()","tspnet.tsp.runscript()","15280.htm"); +Page[482]=new Array("This function writes a string to the remote instrument.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","tspnet.write(connectionID, "inputString")","connectionID","The connection ID returned from tspnet.connect()","inputString","The string to be written","Details","The tspnet.write() function sends inputString to the remote instrument. It does not wait for command completion on the remote instrument.","The 2601B-PULSE sends inputString to the remote instrument exactly as indicated. The inputString must contain any necessary new lines, termination, or other syntax elements needed to complete properly.","Because tspnet.write() does not process output from the remote instrument, do not send commands that generate too much output without processing the output. This command can stop executing if there is too much unprocessed output from previous commands.","Example","tspnet.write(myID, "runscript()\\r\\n")","Commands the remote instrument to execute a command or script named runscript() on a remote device identified in the system as myID.","Also see","tspnet.connect()","tspnet.read()","tspnet.write()","14089.htm"); +Page[483]=new Array("This function adds a user-defined string to nonvolatile memory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","userstring.add("name", "value")","name","The name of the string; the key of the key-value pair","value","The string to associate with name; the value of the key-value pair","Details","This function associates the string value with the string name and stores this key-value pair in nonvolatile memory.","Use the userstring.get() function to retrieve the value associated with the specified name.","You can use the userstring functions to store custom, instrument-specific information in the instrument, such as department number, asset number, or manufacturing plant location.","Example","userstring.add("assetnumber", "236")","userstring.add("product", "Widgets")","userstring.add("contact", "John Doe")","for name in userstring.catalog() do"," print(name .. " = " .."," userstring.get(name))","end","Stores user-defined strings in nonvolatile memory and recalls them from the instrument using a for loop.","Example output:","assetnumber = 236","contact = John Doe","product = Widgets","Also see","userstring.catalog()","userstring.delete()","userstring.get()","userstring.add()","13987.htm"); +Page[484]=new Array("This function creates an iterator for the user‑defined string catalog.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","for name in userstring.catalog() do body end","name","The name of the string; the key of the key-value pair","body","Code to execute in the body of the for loop","Details","The catalog provides access for user‑defined string pairs, allowing you to manipulate all the key-value pairs in nonvolatile memory. The entries are enumerated in no particular order.","Example 1","for name in userstring.catalog() do"," userstring.delete(name)","end","Deletes all user‑defined strings in nonvolatile memory.","Example 2","userstring.add("assetnumber", "236")","userstring.add("product", "Widgets")","userstring.add("contact", "John Doe")","for name in userstring.catalog() do"," print(name .. " = " .."," userstring.get(name))","end","Prints all userstring key‑value pairs.","Output:","product = Widgets","assetnumber = 236","contact = John Doe","Notice the key-value pairs are not listed in the order they were added.","Also see","userstring.add()","userstring.delete()","userstring.get()","userstring.catalog()","13988.htm"); +Page[485]=new Array("This function deletes a user-defined string from nonvolatile memory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","userstring.delete("name")","name","The name (key) of the key-value pair of the user‑defined string to delete","Details","This function deletes the string that is associated with name from nonvolatile memory.","Example","userstring.delete("assetnumber")","userstring.delete("product")","userstring.delete("contact")","Deletes the user-defined strings associated with the assetnumber, product, and contact names.","Also see","userstring.add()","userstring.catalog()","userstring.get()","userstring.delete()","13989.htm"); +Page[486]=new Array("This function retrieves a user-defined string from nonvolatile memory.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","value = userstring.get("name")","value","The value of the user‑defined string key-value pair","name","The name (key) of the user‑defined string","Details","This function retrieves the string that is associated with name from nonvolatile memory.","Example","userstring.add("assetnumber", "236")","value = userstring.get("assetnumber")","print(value)","Create the user-defined string assetnumber, set to a value of 236.","Read the value associated with the user-defined string named assetnumber.","Store it in a variable called value, then print the variable value.","Output:","236","Also see","userstring.add()","userstring.catalog()","userstring.delete()","userstring.get()","13990.htm"); +Page[487]=new Array("This function waits for all previously started overlapped commands to complete.","Type","TSP-Link accessible","Affected by","Where saved","Default value","Function","No","Usage","waitcomplete()","waitcomplete(group)","group","Specifies which TSP-Link group on which to wait","Details","There are two types of instrument commands:","Overlapped commands: Commands that allow the execution of subsequent commands while instrument operations of the overlapped command are still in progress.","Sequential commands: Commands whose operations must finish before the next command is executed.","The waitcomplete() command suspends the execution of commands until the instrument operations of all previous overlapped commands are finished. This command is not needed for sequential commands.","A group number may only be specified when this node is the master node.","If no group is specified, the local group is used.","If zero (0) is specified for the group, this function waits for all nodes in the system.","@
Any nodes that are not assigned to a group (group number is 0) are part of the master node's group.","Example 1","waitcomplete()","Waits for all nodes in the local group.","Example 2","waitcomplete(G)","Waits for all nodes in group G.","Example 3","waitcomplete(0)","Waits for all nodes on the TSP-Link network.","Also see","None","waitcomplete()","13986.htm"); +Page[488]=new Array("See the "2-wire local sensing connections" topic in the 2601B-PULSE reference manual.","2-wire local sensing connections","19568.htm"); +Page[489]=new Array("See the "4-wire remote sensing connections" topic in the 2601B-PULSE reference manual.","4-wire remote sensing connections","19569.htm"); +Page[490]=new Array("See the "Adjustment" topic in the 2601B-PULSE reference manual.","Adjustment","19563.htm"); +Page[491]=new Array("The 2601B-PULSE SMUs have an integrating analog-to-digital converter (ADC). The integrating ADC uses a ratiometric analog-to-digital conversion technique. Depending on the configuration of the integrating ADC, periodic fresh reference measurements are required to minimize drift. The measurement aperture is used to determine the time interval between these measurement updates. For additional information, see Autozero. To help optimize operation of this ADC, the instrument caches the reference and zero values for up to ten of the most recent number of power line cycles. For additional information, see NPLC caching.","Analog-to-digital converter","18560.htm"); +Page[492]=new Array("If a script is created with the loadscript or loadandrunscript command with no name defined, it is called the anonymous script. There can only be one anonymous script in the runtime environment. If another anonymous script is loaded into the runtime environment, it replaces the existing anonymous script.","Anonymous scripts","10835.htm"); +Page[493]=new Array("To use automatic source ranging, press SRC then the AUTO range key.","To use automatic measure ranging, press the MEAS key followed by the AUTO range key. The AUTO indicator turns on when source or measure autoranging is selected.","When autorange is selected, the instrument automatically sets the best range to source or measure the applied signal. The instrument will uprange at 100 percent of the present range.","@When you change a source value, source autoranging is automatically turned off and remains off until you re‑enable it.","Autoranging","13605.htm"); +Page[494]=new Array("The ADC of the 2601B-PULSE uses a ratiometric A/D conversion technique. To ensure reading accuracy, the instrument must periodically obtain fresh measurements of its internal ground and voltage reference. Separate reference and zero measurements are used for each aperture.","As summarized in the table below, there are different settings for autozero. By default, the instrument is set to AUTO, which automatically checks these reference measurements whenever a signal measurement is made. If the reference measurements are out of date when a signal measurement is made, the instrument automatically makes two more A/D conversions, one for the reference and one for the zero, before returning the result. Thus, occasionally, a measurement takes longer than normal.","This extra time can cause problems in sweeps and other test sequences in which measurement timing is critical. To avoid the extra time for the reference measurements in these situations, you can select OFF. This setting disables the automatic reference measurements. Note that with automatic reference measurements disabled, the instrument may gradually drift out of specification.","To minimize the drift, a reference and zero measurement should be made immediately before a critical test sequence. The ONCE setting can be used to force a refresh of the reference and zero measurements used for the current aperture setting.","Autozero settings","Autozero setting","Description","OFF","Turns automatic reference measurements off.","ONCE","After immediately making one reference and one zero measurement, turns automatic reference measurements off. ","AUTO","Automatically takes new acquisitions when the 2601B-PULSE determines reference and zero values are out-of-date.","Autozero","11440.htm"); +Page[495]=new Array("Base library functions","Function","Description","collectgarbage()","collectgarbage(limit)","Sets the garbage-collection threshold to the given limit (in kilobytes) and checks it against the byte counter. If the new threshold is smaller than the byte counter, Lua immediately runs the garbage collector. If there is no limit parameter, it defaults to zero (0), which forces a garbage‑collection cycle. See Lua memory management for more information.","gcinfo()","Returns the number of kilobytes of dynamic memory that the Test Script Processor (TSP®) scripting engine is using and returns the present garbage collector threshold (also in kilobytes). See Lua memory management for more information.","tonumber(x)","tonumber(x, base)","Returns x converted to a number. If x is already a number, or a convertible string, the number is returned; otherwise, it returns nil.","An optional argument specifies the base to use when interpreting the numeral. The base may be any integer from 2 to 36, inclusive. In bases above 10, the letter A (in either upper or lower case) represents 10, B represents 11, and so forth, with Z representing 35. In base 10, the default, the number may have a decimal part, as well as an optional exponent. In other bases, only unsigned integers are accepted.","tostring(x)","Receives an argument of any type and converts it to a string in a reasonable format.","type(v)","Returns (as a string) the type of its only argument. The possible results of this function are "nil" (a string, not the value nil), "number", "string", "boolean", "table", "function", "thread", and "userdata".","Base library functions","2430.htm"); +Page[496]=new Array("See the "Calibration" topic in the 2601B-PULSE reference manual.","Calibration","19570.htm"); +Page[497]=new Array("A history of the key code for the last pressed front‑panel key is maintained by the 2601B-PULSE. When the instrument is turned on (or when transitioning from local to remote operation), the key code is set to 0 (display.KEY_NONE).","When a front‑panel key is pressed, the key code value for that key can be captured and returned. There are two functions associated with the capture of key-press codes: display.getlastkey() and display.waitkey().","Capturing key-press codes","12125.htm"); +Page[498]=new Array("See the "Configuring and running sweeps" topic in the 2601B-PULSE reference manual.","Configuring and running sweeps","19567.htm"); +Page[499]=new Array("See the "Contact check connections" topic in the 2601B-PULSE reference manual.","Contact check connections","19564.htm"); +Page[500]=new Array("See the "Contact check measurements" topic in the 2601B-PULSE reference manual.","Contact check measurements","19565.htm"); +Page[501]=new Array("See the "Controlling digital I/O lines" topic in the 2601B-PULSE reference manual.","Controlling digital I/O lines","11274.htm"); +Page[502]=new Array("See the "Create a script using the script.new() command" topic in the 2601B-PULSE reference manual.","Create a script using the script.new() command","19556.htm"); +Page[503]=new Array("@These steps remove a script from nonvolatile memory. To completely remove a script from the instrument, there are additional steps you must take. See Delete user scripts from the instrument.","To delete a script from nonvolatile memory using a remote interface:","You can delete the script from nonvolatile memory by sending either of the following commands:","script.delete("name")","script.user.delete("name")","Where: name is the user-defined name of the script.","Example: Delete a user script from nonvolatile memory","script.delete("test8")","Delete a user script named test8 from nonvolatile memory.","Delete user scripts","16805.htm"); +Page[504]=new Array("In most circumstances, you can delete a script using script.delete() (as described in Delete user scripts), and then turn the instrument off and back on again. However, if you cannot turn the instrument off, you can use the following steps to completely remove a script from the instrument.","When you completely remove a script, you delete all references to the script from the runtime environment, the script.user.scripts table, and nonvolatile memory.","To completely remove a script:","Remove the script from the runtime environment. Set any variables that refer to the script to nil or assign the variables a different value. For example, to remove the script "beepTwoSec" from the runtime environment, send the following code:
beepTwoSec = nil","Remove the script from the script.user.scripts table. Set the name attribute to an empty string (""). This makes the script nameless, but does not make the script become the anonymous script. For example, to remove the script named "beepTwoSec", send the following code:
script.user.scripts.beepTwoSec.name = ""","Remove the script from nonvolatile memory. To delete the script from nonvolatile memory, send the command:
script.delete("name")","Where name is the name that the script was saved as. For example, to delete "beepTwoSec", you would send:
script.delete("beepTwoSec")","Delete user scripts from the instrument","2408.htm"); +Page[505]=new Array("See the "Digital I/O" topic in the 2601B-PULSE reference manual.","Digital I/O","19553.htm"); +Page[506]=new Array("Bit weighting for the digital I/O lines is shown in the following table.","Digital bit weight","Line #","Bit","Decimal weighting","Hexadecimal weighting","1","B1","1","0x0001","2","B2","2","0x0002","3","B3","4","0x0004","4","B4","8","0x0008","5","B5","16","0x0010","6","B6","32","0x0020","7","B7","64","0x0040","8","B8","128","0x0080","9","B9","256","0x0100","10","B10","512","0x0200","11","B11","1,024","0x0400","12","B12","2,048","0x0800","13","B13","4,096","0x1000","14","B14","8,192","0x2000","Digital I/O bit weighting","11500.htm"); +Page[507]=new Array("The Keithley Instruments 2601B-PULSE System SourceMeter® instrument has a digital input/output port that can be used to control external digital circuitry. For example, a handler that is used to perform binning operations can be used with a digital I/O port.","Digital I/O port","12451.htm"); +Page[508]=new Array("Use the DISPLAY key to scroll through the display modes shown in the figure below.","Display mode","92127.htm"); +Page[509]=new Array("Display resolution for measured readings can be set to 4-1/2, 5-1/2 or 6-1/2. Configure the type of resolution displayed by setting the display.smua.digits attribute. The following programming example illustrates how to set 5-1/2 digit resolution for measured readings:","display.smua.digits = display.DIGITS_5_5","Display resolution","12137.htm"); +Page[510]=new Array("See the "DUT test connections" topic in the 2601B-PULSE reference manual.","DUT test connections","19573.htm"); +Page[511]=new Array("The error queue holds error and status messages. As programming errors and status messages occur, a message that defines the error or status is placed in the error queue.","An error or status message is cleared from the error queue when it is read. You can also clear the error queue by sending the command errorqueue.clear(). An empty error queue clears the error available (EAV) bit in the Status Byte Register.","Messages in the error queue include a code number, message text, severity, and TSP-Link® node number. See Error summary list for a list of the messages.","When you read a single message from the error queue, the oldest message is read. If you attempt to read the error queue when it is empty, the error number 0 and “No Error” is returned.","The commands that can be used to control the error queue are listed below.","Error queue commands","Error queue command","Description","errorqueue.clear()","Clear error queue of all errors.","errorqueue.count","Number of messages in the error/event queue.","errorCode, message,"," severity, errorNode ="," errorqueue.next()","Request error code, text message, severity, and TSP-Link node number.","Error queue","12259.htm"); +Page[512]=new Array("Error summary","Error number","Error level","Error message","-430","RECOVERABLE","Query DEADLOCKED","-420","RECOVERABLE","Query UNTERMINATED","-410","RECOVERABLE","Query INTERRUPTED","-363","RECOVERABLE","Input buffer overrun","-360","RECOVERABLE","Communications error","-350","RECOVERABLE","Queue overflow","-315","RECOVERABLE","Configuration memory lost","-314","RECOVERABLE","Save/recall memory lost","-292","RECOVERABLE","Referenced name does not exist","-286","RECOVERABLE","TSP Runtime error","-285","RECOVERABLE","Program syntax","-282","RECOVERABLE","Illegal program name","-281","RECOVERABLE","Cannot create program","-225","RECOVERABLE","Out of memory or TSP Memory allocation error","-224","RECOVERABLE","Illegal parameter value","-222","RECOVERABLE","Parameter data out of range","-221","RECOVERABLE","Settings conflict","-220","RECOVERABLE","Parameter error","-211","RECOVERABLE","Trigger ignored","-203","RECOVERABLE","Command protected","-154","RECOVERABLE","String too long","-151","RECOVERABLE","Invalid string data","-110","RECOVERABLE","Command header error","-109","RECOVERABLE","Missing parameter","-108","RECOVERABLE","Parameter not allowed","-105","RECOVERABLE","Trigger not allowed","-104","RECOVERABLE","Data type error","0","NO_SEVERITY","Queue Is Empty","503","RECOVERABLE","Calibration overflow","601","RECOVERABLE","Reading buffer data lost","603","RECOVERABLE","Power on state lost","702","FATAL","Unresponsive digital FPGA","802","RECOVERABLE","OUTPUT blocked by interlock","819","RECOVERABLE","Error parsing exponent","820","RECOVERABLE","Error parsing value","900","FATAL","Internal system error","1100","RECOVERABLE","Command unavailable","1101","RECOVERABLE","Parameter too big","1102","RECOVERABLE","Parameter too small","1103","RECOVERABLE","Min greater than max","1104","RECOVERABLE","Too many digits for param type","1105","RECOVERABLE","Too many parameters","1107","RECOVERABLE","Cannot modify factory menu","1108","RECOVERABLE","Menu name does not exist","1109","RECOVERABLE","Menu name already exists","1110","FATAL","Analog supply failure: over temperature","1113","RECOVERABLE","Data too complex","1122","SERIOUS","Interlock or power supply failure","1200","RECOVERABLE","TSP-Link initialization failed","1202","RECOVERABLE","TSP-Link initialization failed","1203","RECOVERABLE","TSP-Link initialization failed (possible loop in node chain)","1204","RECOVERABLE","TSP-Link initialization failed","1205","RECOVERABLE","TSP-Link initialization failed (no remote nodes found)","1206","RECOVERABLE","TSP-Link initialization failed","1207","RECOVERABLE","TSP-Link initialization failed","1208","RECOVERABLE","TSP-Link initialization failed","1209","RECOVERABLE","TSP-Link initialization failed","1210","RECOVERABLE","TSP-Link initialization failed (node ID conflict)","1211","RECOVERABLE","Node NN is inaccessible","1212","RECOVERABLE","Invalid node ID","1213","RECOVERABLE","TSP-Link session expired","1215","RECOVERABLE","Code execution requested within the local group","1216","RECOVERABLE","Remote execution requested on node in group with pending overlapped operations","1217","RECOVERABLE","Remote execution requested on node outside the local group","1218","RECOVERABLE","Operation allowed only when TSP-Link master","1219","RECOVERABLE","TSP-Link found fewer nodes than expected","1400","RECOVERABLE","Expected at least NN parameters","1401","RECOVERABLE","Parameter NN is invalid","1402","RECOVERABLE","User scripts lost","1403","RECOVERABLE","Factory scripts lost","1404","RECOVERABLE","Invalid byte order","1405","RECOVERABLE","Invalid ASCII precision","1406","RECOVERABLE","Invalid data format","1500","RECOVERABLE","Invalid baud rate setting","1501","RECOVERABLE","Invalid parity setting","1502","RECOVERABLE","Invalid terminator setting","1503","RECOVERABLE","Invalid bits setting","1504","RECOVERABLE","Invalid flow control setting","1600","RECOVERABLE","Maximum GPIB message length exceeded","1700","RECOVERABLE","Display area boundary exceeded","1800","RECOVERABLE","Invalid digital trigger mode","1801","RECOVERABLE","Invalid digital I/O line","2000","SERIOUS","Flash download error","2001","RECOVERABLE","Cannot flash with error in queue","2101","FATAL","Could not close socket","2102","RECOVERABLE","Lan configuration already in progress","2103","RECOVERABLE","Lan disabled","2104","RECOVERABLE","Socket error","2105","RECOVERABLE","Unreachable gateway","2106","RECOVERABLE","Could not acquire ip address","2110","RECOVERABLE","Could not resolve hostname","2111","RECOVERABLE","DNS name (FQDN) too long","2112","RECOVERABLE","Connection not established","2200","RECOVERABLE","File write error","2201","RECOVERABLE","File read error","2202","RECOVERABLE","Cannot close file","2203","RECOVERABLE","Cannot open file","2204","RECOVERABLE","Directory not found","2205","RECOVERABLE","File not found","2206","RECOVERABLE","Cannot read current working directory","2207","RECOVERABLE","Cannot change directory","2211","RECOVERABLE","File system error","2212","RECOVERABLE","File system command not supported","2213","RECOVERABLE","Too many open files","2214","RECOVERABLE","File access denied","2215","RECOVERABLE","Invalid file handle","2216","RECOVERABLE","Invalid drive","2217","RECOVERABLE","File system busy","2218","RECOVERABLE","Disk full","2219","RECOVERABLE","File corrupt","2220","RECOVERABLE","File already exists","2221","RECOVERABLE","File seek error","2222","RECOVERABLE","End-of-file error","2223","RECOVERABLE","Directory not empty","2400","RECOVERABLE","Invalid specified connection","2401","RECOVERABLE","Invalid timeout seconds (.001 to 30)","2402","RECOVERABLE","TSPnet remote error: XXX, where XXX explains the remote error","2403","RECOVERABLE","TSPnet failure","2404","RECOVERABLE","TSPnet read failure","2405","RECOVERABLE","TSPnet read failure, aborted","2406","RECOVERABLE","TSPnet read failure, timeout","2407","RECOVERABLE","TSPnet write failure","2408","RECOVERABLE","TSPnet write failure, aborted","2409","RECOVERABLE","TSPnet write failure, timeout","2410","RECOVERABLE","TSPnet max connections reached","2411","RECOVERABLE","TSPnet connection failed","2412","RECOVERABLE","TSPnet invalid termination","2413","RECOVERABLE","TSPnet invalid reading buffer table","2414","RECOVERABLE","TSPnet invalid reading buffer index range","2415","RECOVERABLE","TSPnet feature only supported on TSP connections","2416","RECOVERABLE","TSPnet must specify both port and init","2417","RECOVERABLE","TSPnet disconnected by other side","2418","RECOVERABLE","TSPnet read input buffer overflow","2419","RECOVERABLE","Invalid format specifier","2420","RECOVERABLE","Termination locked while using TSP connection","2500","RECOVERABLE","Average delay must be at least NNN seconds","4900","RECOVERABLE","Reading buffer index NN is invalid","4903","RECOVERABLE","Reading buffer expired","4904","SERIOUS","ICX parameter count mismatch, %s (Line #%d)","4905","SERIOUS","ICX parameter invalid value, %s (Line #%d)","4906","SERIOUS","ICX invalid function id, %s (Line #%d)","5001","FATAL","SMU is unresponsive. Disconnect DUT and cycle power","5003","SERIOUS","Saved calibration constants corrupted","5004","RECOVERABLE","Operation conflicts with CALA sense mode","5005","RECOVERABLE","Value too big for range","5007","RECOVERABLE","Operation would exceed safe operating area of the instrument","5008","RECOVERABLE","Operation not permitted while OUTPUT is on","5009","SERIOUS","Unknown sourcing function","5010","SERIOUS","No such SMU function","5011","RECOVERABLE","Operation not permitted while cal is locked","5012","RECOVERABLE","Cal data not saved - save or restore before lock","5013","RECOVERABLE","Cannot save cal data - unlock before save","5014","RECOVERABLE","Cannot restore cal data - unlock before restore","5015","RECOVERABLE","Save to cal set disallowed","5016","RECOVERABLE","Cannot change cal date - unlock before operation","5017","RECOVERABLE","Cannot change cal constants - unlock before operation","5018","SERIOUS","Cal version inconsistency","5019","RECOVERABLE","Cannot unlock - invalid password","5021","SERIOUS","Cannot restore default calset. Using previous calset","5022","SERIOUS","Cannot restore previous calset. Using factory calset","5023","SERIOUS","Cannot restore factory calset. Using nominal calset","5024","SERIOUS","Cannot restore nominal calset. Using firmware defaults","5025","RECOVERABLE","Cannot set filter.count > 1 when measure.count > 1","5027","RECOVERABLE","Unlock cal data with factory password","5028","RECOVERABLE","Cannot perform requested operation while source autorange is enabled","5029","RECOVERABLE","Cannot save without changing cal adjustment date","5032","RECOVERABLE","Cannot change this setting unless buffer is cleared","5033","RECOVERABLE","Reading buffer not found within device","5038","RECOVERABLE","Index exceeds maximum reading","5040","RECOVERABLE","Cannot use same reading buffer for multiple overlapped measurements","5042","RECOVERABLE","Cannot perform requested action while an overlapped operation is in progress","5043","RECOVERABLE","Cannot perform requested operation while voltage measure autorange is enabled","5044","RECOVERABLE","Cannot perform requested operation while current measure autorange is enabled","5045","RECOVERABLE","Cannot perform requested operation while filter is enabled","5046","SERIOUS","SMU too hot","5047","RECOVERABLE","Minimum timestamp resolution is 1us","5048","RECOVERABLE","Contact check not valid with HIGH-Z OUTPUT off","5049","RECOVERABLE","Contact check not valid while an active current source","5050","RECOVERABLE","I limit too low for contact check","5051","FATAL","Model number/SMU hardware mismatch. Disconnect DUT and cycle power","5053","RECOVERABLE","Unstable output detected - Measurements may not be valid","5055","RECOVERABLE","Cannot change adjustment date - change cal constants before operation","5059","RECOVERABLE","trigger.source.action enabled without configuration","5060","RECOVERABLE","trigger.measure.action enabled without configuration","5061","RECOVERABLE","Operation not permitted while OUTPUT is off","5062","SERIOUS","SMU overload. Automatic OUTPUT off.","5063","RECOVERABLE","Cannot perform requested operation while measure autozero is on","5064","RECOVERABLE","Cannot use reading buffer that collects source values","5065","RECOVERABLE","I range too low for contact check","5066","RECOVERABLE","source.offlimiti too low for contact check","5069","SERIOUS","Autorange locked for HighC mode","5108","RECOVERABLE","Maximum pulse width exceeded","5109","RECOVERABLE","Maximum duty cycle exceeded","5111","RECOVERABLE","Total measure time exceeds pulse width","5126","RECOVERABLE","Operation not permitted while pulser is enabled","5127","RECOVERABLE","Output protection level exceeded","5128","RECOVERABLE","Pulse width too small","5129","RECOVERABLE","Measure time exceeds measure interval ","5130","RECOVERABLE","Filter type not permitted while pulser is enabled ","5131","RECOVERABLE","Current source as off-function not permitted while pulser is enabled","5132","RECOVERABLE","Voltage sweeps not permitted while pulser is enabled","5133","RECOVERABLE","Measure stimulus not allowed with pulser measure delay when pulser is enabled","5134","RECOVERABLE","Measure stimulus requires asynchronous measure when pulser is enabled","5135","RECOVERABLE","Measure not permitted with output off when pulser is enabled","5136","RECOVERABLE","Measure count too big with pulser enabled","5137","RECOVERABLE","Measure interval too big with pulser enabled","5138","RECOVERABLE","trigger.source.action required when pulser is enabled","5139","RECOVERABLE","trigger.source.stimulus required when pulser is enabled","5140","RECOVERABLE","Measure stimulus or measure delay required when pulser is enabled","5141","RECOVERABLE","Pulse width not permitted when pulser is disabled","5142","RECOVERABLE","Measure count multiplied by filter count is too big","5143","RECOVERABLE","End pulse stimulus or pulse width required when pulser is enabled","5144","RECOVERABLE","Maximum measurement rate exceeded","5145","RECOVERABLE","Maximum pulse rate exceeded","Error summary list","93187.htm"); +Page[513]=new Array("The filter feature lets you set the filter response to stabilize noisy measurements. The 2601B-PULSE uses a digital filter, which is based on reading conversions. The displayed, stored, or transmitted reading is calculated using one or more reading conversions (from 1 to 100).","Filters","11532.htm"); +Page[514]=new Array("See the "Front panel" topic in the 2601B-PULSE reference manual.","Front panel","93212.htm"); +Page[515]=new Array("See the "Global variables and the script.user.scripts table" topic in the 2601B-PULSE reference manual.","Global variables and the script.user.scripts table","19557.htm"); +Page[516]=new Array("See the "GPIB setup" topic in the 2601B-PULSE reference manual.","GPIB setup","24524.htm"); +Page[517]=new Array("See the "High-capacitance mode" topic in the 2601B-PULSE reference manual.","High-capacitance mode","19566.htm"); +Page[518]=new Array("See the "Load a script by sending commands over the remote interface" topic in the 2601B-PULSE reference manual.","Load a script by sending commands over the remote interface","19559.htm"); +Page[519]=new Array("The logical operators in Lua are and, or, and not. All logical operators consider both false and nil as false and anything else as true.","The operator not always returns false or true.","The conjunction operator and returns its first argument if the first argument is false or nil; otherwise, and returns its second argument. The disjunction operator or returns its first argument if this value is different from nil and false; otherwise, or returns its second argument. Both and and or use shortcut evaluation, that is, the second operand is evaluated only if necessary.","@
The example output you get may vary depending on the data format settings of the instrument.","Example","print(10 or errorqueue.next())","print(nil or "a")","print(nil and 10)","print(false and errorqueue.next())","print(false and nil)","print(false or nil)","print(10 and 20)","1.00000e+01","a","nil","false","false","nil","2.00000e+01","Logical operators","12893.htm"); +Page[520]=new Array("The measure delay is a specific delay that is applied before each measurement is made. This delay is disabled by default (measurements are made immediately). You can change the default delay by setting the smua.measure.delay attribute either to a specific value or to an auto delay setting (set smua.measure.delay = smua.DELAY_AUTO). If the measure delay is set to the auto delay setting, a range-dependent delay is applied each time the instrument performs a current measurement. This delay also happens for the measurement that is taken after changing current ranges during an autoranged measurement. The default measurement delay varies by model.","You can increase or decrease the auto delay by changing the delay factor (for example, to reduce the delay across all ranges by half, set smua.measure.delayfactor = 0.5). For additional information, refer to smua.measure.delayfactor in the "Remote commands" section.","Measure auto delay","19632.htm"); +Page[521]=new Array("See the "Measurement event registers" topic in the 2601B-PULSE reference manual.","Measurement event registers","19571.htm"); +Page[522]=new Array("See the "Named scripts" topic in the 2601B-PULSE reference manual.","Named scripts","19558.htm"); +Page[523]=new Array("See the "Operation Status Registers" topic in the 2601B-PULSE reference manual.","Operation Status Registers","19578.htm"); +Page[524]=new Array(" ","@Carefully consider and configure the appropriate output-off state, source, and compliance limits before connecting the 2601B-PULSE to a device that can deliver energy (for example, other voltage sources, batteries, capacitors, solar cells, or other 2601B-PULSE instruments). Configure recommended instrument settings before making connections to the device. Failure to consider the output-off state, source, and compliance limits may result in damage to the instrument or to the device under test (DUT).","Output-off states","15424.htm"); +Page[525]=new Array("See the "Pulser operation" topic in the 2601B-PULSE reference manual.","Pulser operation","93214.htm"); +Page[526]=new Array("See the "Questionable Status Registers" topic in the 2601B-PULSE reference manual.","Questionable Status Registers","19579.htm"); +Page[527]=new Array("See the "Queues" topic in the 2601B-PULSE reference manual.","Queues","19552.htm"); +Page[528]=new Array("The selected measurement range affects the accuracy of the measurements and the maximum signal that can be measured. If the range is changed, the front‑panel display may contain dashes instead of a reading (for example, --.---- mA). This indicates that no measurement was made using the range that is presently selected. To update the displayed reading, trigger a measurement (if in local control, press the TRIG key).","Range","11993.htm"); +Page[529]=new Array("Reading buffers capture measurements, ranges, instrument status, and output state of the Keithley Instruments 2601B-PULSE. The 2601B-PULSE has two default reading buffers. In addition to the default buffers, you can create user-defined reading buffers. You can use the reading buffers to acquire readings.","You can access reading buffers from the front panel or over the remote command interface.","The default reading buffers can store can store over 60,000 readings if you enable the options for timestamps and source values. To store over 140,000 readings internally, you can disable the timestamps and source values.","You can save reading buffers to internal nonvolatile memory in the instrument or to a USB flash drive.","Once you save the reading buffers to a USB flash drive, insert the USB flash drive into the USB port on your computer to view the data in any compatible data analysis application or to transfer the data from the USB flash drive to your computer.","Overview","13629.htm"); +Page[530]=new Array("When making measurements, you may want to subtract an offset value from a measurement. ","The relative offset feature subtracts a set value or a baseline reading from measurement readings. When you enable relative offset, all measurements are recorded as the difference between the actual measured value and the relative offset value. The formula to calculate the offset value is:","Displayed value = Actual measured value - Relative offset value","When a relative offset value is established for a measure function, the value is the same for all ranges for that measure function. For example, if 0.5 A is set as a relative offset value on the 1 A range, the relative offset value is also 0.5 A on the lower current ranges. Also, on the 1 A range, the 2601B-PULSE still overflows for a more than 1.02 A input.","When relative offset is enabled, the REL indicator turns on. Changing measurement functions changes the relative offset value to the established relative offset value and state for that measurement function.","Relative offset","12001.htm"); +Page[531]=new Array("You can get readings by making overlapped or sequential measurements. Overlapped commands do not finish executing before the next command starts. Sequential commands complete execution before the next command starts executing.","The measured value is not the only component of a reading. The measurement status (for example, “In Compliance” or “Overranged”) is also an element of data associated with a particular reading.","All routines that return measurements can store the measurements in the reading buffers. Overlapped measurements always return readings in a reading buffer. Non-overlapped measurement functions can return single-point measurement values or store multiple values in a reading buffer.","A reading buffer is based on a Lua table. The measurements are accessed by ordinary array accesses. If rb is a reading buffer, the first measurement is accessed as rb[1] and the ninth measurement as rb[9]. The additional information in the table is accessed as additional members of the table.","The load, save, and write operations for reading buffers function differently in the remote state. From a remote command interface, you can extract data from reading buffers as the instrument acquires the data.","Remote reading buffer programming","11655.htm"); +Page[532]=new Array("The node that acquires the data also stores the data for the reading buffer. To optimize data access, all nodes can cache data from the node that stores the reading buffer data.","When you run Lua code remotely, it can cause reading buffer data that is held in the cache to become stale. If the values in the reading buffer change while the Lua code runs remotely, another node can hold stale values. Use the clearcache() command to clear the cache. For additional detail on the reading buffer cache commands, see bufferVar.cachemode and bufferVar.clearcache().","The following example code demonstrates how stale values occur and how to use the clearcache() command to clear the cache on node 2, which is part of group 7.","-- Create a reading buffer on a node in a remote group.","node[2].tsplink.group = 7","node[2].execute("rbremote = smua.makebuffer(20)" .."," "smua.measure.count = 20 " .."," "smua.measure.v(rbremote)")","-- Create a variable on the local node to","-- access the reading buffer.","rblocal = node[2].getglobal("rbremote")","-- Access data from the reading buffer.","print(rblocal[1])","-- Run code on the remote node that updates the reading buffer.","node[2].execute("smua.measure.v(rbremote)")","-- Use the clearcache command if the reading buffer contains cached data.","rblocal.clearcache()","-- If you do not use the clearcache command, the data buffer","-- values will never update. Every time the print command is","-- issued after the first print command, the same data buffer","-- values will print.","print(rblocal[1])","Removing stale values from the reading buffer cache","3249.htm"); +Page[533]=new Array("See the "Rename a script" topic in the 2601B-PULSE reference manual.","Rename a script","19560.htm"); +Page[534]=new Array("To retrieve the source code one line at a time, send the scriptVar.list() command. When this command is received, the instrument sends the entire script. Each line of the script is sent as a separate response message. The output includes the loadscript or loadandrunscript and endscript keywords.","After retrieving the source code, you can modify and save the command lines as a user script under the same name or a new name.","To retrieve the source code of a script one line at a time, send the command:","scriptVar.list()","Where scriptVar is the name of the script.","@To retrieve the commands in the anonymous script, use script.anonymous.list().","Example: Retrieve source code one line at a time","test.list()","Retrieve the source of a script named "test".","The output will look similar to:","loadscript test","display.clear()","display.settext("This is a test")","print("This is a test")","endscript ","Retrieve source code one line at a time","17030.htm"); +Page[535]=new Array("See the "RS-232 interface operation" topic in the 2601B-PULSE reference manual.","RS-232 interface operation","19561.htm"); +Page[536]=new Array("You can save scripts to nonvolatile memory using commands.","Only named scripts can be saved to nonvolatile memory. The anonymous script must be named before it can be saved to nonvolatile memory.","@If a script is not saved to nonvolatile memory, the script is lost when the instrument is turned off.","Save a user script","16803.htm"); +Page[537]=new Array("See the "Saved setups" topic in the 2601B-PULSE reference manual.","Saved setups","19562.htm"); +Page[538]=new Array("The sense mode can be set to use 2-wire local sensing connections or 4-wire remote sensing connections. The default sense setting is 2-wire local.","Sense mode selection","11848.htm"); +Page[539]=new Array("See the "Setting a value" topic in the 2601B-PULSE reference manual.","Setting a value","29272.htm"); +Page[540]=new Array("Depending on how it is programmed and what is connected to the output (load or source), the instrument can operate in any of the four quadrants. The four quadrants of operation are shown in the continuous operating boundaries figures. When operating in the first (I) or third (III) quadrant, the instrument is operating as a source (V and I have the same polarity). As a source, the instrument is delivering power to a load.","When operating in the second (II) or fourth (IV) quadrant, the instrument is operating as a sink (V and I have opposite polarity). As a sink, it is dissipating power rather than sourcing it. An external source or an energy storage device, such as a capacitor or battery, can force operation in the sink region.","Source or sink","11584.htm"); +Page[541]=new Array("See the "Source-measure concepts" topic in the 2601B-PULSE reference manual.","Source-measure concepts","19572.htm"); +Page[542]=new Array(" The SPEED key can select and control the analog-to-digital converter (ADC) through setting the integration time, or measurement aperture (the period of time the input signal is measured). The integration time affects the usable digits, the amount of reading noise, and the reading rate of the instrument. The integration time is specified in parameters based on the number of power line cycles (NPLC), where 1 PLC for 60 Hz is 16.67 ms (1/60) and 1 PLC for 50 Hz is 20 ms (1/50).","In general, the fastest integration time (0.001 PLC) results in the fastest reading rate, but also causes increased reading noise and fewer usable digits. The slowest integration time (25 PLC) provides the best common-mode and normal-mode noise rejection, but has the slowest reading rate. Settings between the fastest and slowest integration times are a compromise between speed and noise. The default power‑on speed setting is NORMAL (1 PLC).","Speed","11998.htm"); +Page[543]=new Array("See the "Standard Event Register" topic in the 2601B-PULSE reference manual.","Standard Event Register","19580.htm"); +Page[544]=new Array("You can specify the 2601B-PULSE start-up (power-on) configuration. Use the setup.poweron attribute to select which setup to return to upon power-up. To set the setup.poweron configuration attribute:","setup.poweron = n -- Select power-on setup.","Where n is:","0 (*RST or reset() factory defaults)","1 to 5 (user setup 1 to 5)","Start-up (power-on) configuration","11613.htm"); +Page[545]=new Array("See the "Status byte and service request (SRQ)" topic in the 2601B-PULSE reference manual.","Status byte and service request (SRQ)","19576.htm"); +Page[546]=new Array("See the "Status Model" topic in the Model 2601B-PULSE Reference Manual.","Status model","19551.htm"); +Page[547]=new Array("See the "Status model overview" topic in the 2601B-PULSE reference manual.","Status model overview","19575.htm"); +Page[548]=new Array("See the "Sweep operation" topic in the 2601B-PULSE reference manual.","Sweep operation","19550.htm"); +Page[549]=new Array("See the "System summary and standard event registers" topic in the 2601B-PULSE reference manual.","System summary and standard event registers","19581.htm"); +Page[550]=new Array("See the "Triggering" topic in the 2601B-PULSE reference manual.","Triggering","19574.htm"); +Page[551]=new Array("See the "TSP advanced features" topic in the 2601B-PULSE reference manual.","TSP advanced features","19555.htm"); +Page[552]=new Array("See the "TSP-Link" topic in the 2601B-PULSE reference manual.","TSP-Link","19554.htm"); +Page[553]=new Array("The 2601B-PULSE has three trigger lines that you can use for triggering, digital I/O, and to synchronize multiple instruments on a TSP-Link® network.","TSP-Link trigger lines","92304.htm"); +Page[554]=new Array("LAN triggering is similar to hardware synchronization except that LXI trigger packets are used instead of hardware signals. A bit in the LXI trigger packet called the hardware value simulates the state of a hardware trigger line. The 2601B-PULSE stores the hardware value of the last LXI trigger packet that was sent or received as the pseudo line state.","The stateless event flag is a bit in the LXI trigger packet that indicates if the hardware value should be ignored. If it is set, the 2601B-PULSE ignores the hardware value of the packet and generates a trigger event. The 2601B-PULSE always sets the stateless flag for outgoing LXI trigger packets. If the stateless event flag is not set, the hardware value indicates the state of the signal.","Changes in the hardware value of consecutive LXI trigger packets are interpreted as edge transitions. Edge transitions generate trigger events. If the hardware value does not change between successive LXI trigger packets, the 2601B-PULSE assumes an edge transition was missed and generates a trigger event. The following table illustrates edge detection in LAN triggering.","LXI trigger edge detection","Stateless event flag","Hardware value","Pseudo line state","Falling edge","Rising edge","0","0","0","Detected","Detected","0","1","0","-","Detected","0","0","1","Detected","-","0","1","1","Detected","Detected","1","-","-","Detected","Detected","Set the LAN trigger mode to configure the edge detection method in incoming LXI trigger packets. The mode that is selected also determines the hardware value in outgoing LXI trigger packets. The following table lists the LAN trigger modes.","LAN trigger modes","Trigger mode","Input detected","Output generated","Notes","Either edge","Either","Negative","Falling edge","Falling","Negative","Rising edge","Rising","Positive","RisingA","Rising","Positive","Same as Rising","RisingM","Rising","Positive","Same as Rising","Synchronous","Falling","Positive","Same as SynchronousA","SynchronousA","Falling","Positive","SynchronousM","Rising","Negative","The programming example below illustrates how to configure the LAN trigger mode.","-- Set LAN trigger 2 to have falling-edge mode.","lan.trigger[2].mode = lan.TRIG_FALLING","Understanding hardware value and pseudo line state","12571.htm"); +Page[555]=new Array("See the "Upgrading the firmware" topic in the 2601B-PULSE reference manual.","Upgrading the firmware","93219.htm"); +Page[556]=new Array("The primary purpose of groups is to allow each group to run a different test script simultaneously.","A group can consist of one or more nodes. You must assign group numbers to each node using remote commands. If you do not assign a node to a group, it defaults to group 0, which will always be grouped with the master node (regardless of the group to which the master node is assigned).","Using groups to manage nodes on TSP-Link network","3240.htm"); +Page[557]=new Array("Nodes that are running test scripts at the same time can store data in the data queue for real-time communication. Each instrument has an internal data queue that uses the first-in, first-out (FIFO) structure to store data. You can use the data queue to post numeric values, strings, and tables. ","Use the data queue commands to:","Share data between test scripts running in parallel","Access data from a remote group or a local node on a TSP‑Link® network at any time","You cannot access the reading buffers or global variables from any node in a remote group while a node in that group is performing an overlapped operation. However, you can use the data queue to retrieve data from any node in a group that is performing an overlapped operation. In addition, the master node and the group leaders can use the data queue to coordinate activities.","Tables in the data queue consume one entry. When a node stores a table in the data queue, a copy of the data in the table is made. When the data is retrieved from the data queue, a new table is created on the node that is retrieving the data. The new table contains a separate copy of the data in the original table, with no references to the original table or any subtables.","You can access data from the data queue even if a remote group or a node has overlapped operations in process. See the dataqueue commands in the TSP command reference for more information.","Using the data queue for real-time communication","3247.htm"); +Page[558]=new Array("See the "Using the interlock" topic in the 2601B-PULSE reference manual.","Using the interlock","93213.htm"); +var PageCount=559; + +function search(SearchWord){ +var Result=""; +var NrRes=0; +Result='\n'; +Result+="\n"; +Result+="\n"; +Result+="\n"; +Result+="Search Results\n"; +Result+='\n'; +Result+='\n'; +Result+="\n"; +Result+="\n"; +Result+="\n"; +Result+='\n'; +Result+=''; +Result+='
Enter a keyword or phrase
'; +Result+='
'; +if(SearchWord.length>=1){ + while(SearchWord.indexOf("<")>-1 || SearchWord.indexOf(">")>-1 || SearchWord.indexOf('"')>-1){ + SearchWord=SearchWord.replace("<","<").replace(">",">").replace('"',"""); + } +} +Result+=''; +Result+=' 
'; +Result+='
\n'; + +if(SearchWord.length>=1){ + SearchWord=SearchWord.toLowerCase(); + this.status="Searching, please wait..."; + Result+=""; + for(j=0;j-1){ + FoundWord=Page[j][i].substr(WordPos,SearchWord.length); + NrRes++; + Result+=""; + break; + } + } + } + Result+="
"; + Result+=""+Page[j][k-1].replace(FoundWord,FoundWord.bold())+"
\n"; + + if(i350){ + Result+="..."+Page[j][i].substr(WordPos-100,200+FoundWord.length).replace(FoundWord,FoundWord.bold())+"...\n"; + } + else{ + Result+=Page[j][i].replace(FoundWord,FoundWord.bold())+"\n"; + } + } + Result+="
"; + Result+="

 " + NrRes + " result(s) found.

"; +} + +Result+=""; +this.status=""; +this.document.open(); +this.document.write(Result); +this.document.close(); +} \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/exampleinstrumentcommanddescription.png b/WebHelpDocs/2601B-PULSE/exampleinstrumentcommanddescription.png new file mode 100644 index 0000000000000000000000000000000000000000..b973f9bcc8377a295793206d3392707bff0dbe27 GIT binary patch literal 17356 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 Wg`S@0yL;Q)+dGP1i%AGDSOWl@qf+Jo literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/index2.gif b/WebHelpDocs/2601B-PULSE/index2.gif new file mode 100644 index 0000000000000000000000000000000000000000..8069c0667a9792903a1570608cad332b732ae69d GIT binary patch literal 1008 zcmZ?wbhEHbv|^BE_|5+Fyy8-? zzoA<1jwzYG%UzA1WtNoo)F3`rgi$UUjD`vZ4q|Dw0YzuRxEl-lcS W8i}Xp`R?BK_V$kA*ZX7z7_0$a=vz?$ literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/index3.gif b/WebHelpDocs/2601B-PULSE/index3.gif new file mode 100644 index 0000000000000000000000000000000000000000..d44505a110a71f2104e62103c3e95e88ed4a3ef1 GIT binary patch literal 1008 zcmZ?wbhEHbG-Hrv_|5&!vevbk>BpyqYMZY;urB^!*V5Hx>rU^;o*%YV zs$_lqqMA;*qugTYVf*y?ult^~!Pb}oyXyK(F5 X>*C?3=lSm5_V)IU;@5r>0u0swzFS#` literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/index_template.htm b/WebHelpDocs/2601B-PULSE/index_template.htm new file mode 100644 index 0000000..9572f4c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/index_template.htm @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + +
+ +
+ +
+ + \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/jh_index.xml b/WebHelpDocs/2601B-PULSE/jh_index.xml new file mode 100644 index 0000000..a349e6c --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/jh_index.xml @@ -0,0 +1,9 @@ + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/jh_project.hs b/WebHelpDocs/2601B-PULSE/jh_project.hs new file mode 100644 index 0000000..45c5f82 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/jh_project.hs @@ -0,0 +1,40 @@ + + + + + + + Java Development Environment - Help + + + + top + + + + + + TOC + + javax.help.TOCView + IdeHelpTOC.xml + + + + Index + + javax.help.IndexView + IdeHelpIndex.xml + + + + Search + + javax.help.SearchView + + JavaHelpSearch + + + diff --git a/WebHelpDocs/2601B-PULSE/jh_toc.xml b/WebHelpDocs/2601B-PULSE/jh_toc.xml new file mode 100644 index 0000000..4f0db03 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/jh_toc.xml @@ -0,0 +1,4 @@ + + + + \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/map.jhm b/WebHelpDocs/2601B-PULSE/map.jhm new file mode 100644 index 0000000..972137d --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/map.jhm @@ -0,0 +1,571 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/notesmall_lr.png b/WebHelpDocs/2601B-PULSE/notesmall_lr.png new file mode 100644 index 0000000000000000000000000000000000000000..aa01d00184145d9e9599a9b15cc205aeca2ce9e7 GIT binary patch literal 369 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 |YQKx3ndo&|bsS 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

4hn)6x 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 aZG5JJg&*08a+U(+w~ZG^;_-j`>i+|F%s~GD literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/search1.gif b/WebHelpDocs/2601B-PULSE/search1.gif new file mode 100644 index 0000000000000000000000000000000000000000..098b38db188a91b2a4eb92b6a3011070f3b05487 GIT binary patch literal 1043 zcmZ?wbhEHbbYYNY_|5dbWkRfJ=a3^YZi4*aMXmvL-xtWC%!Sis;;u*|^kG z&`)%SY3lVR`^`*Ov$h-vZ%SO-SNqFED|~yw!&$bo!*U&2{BD=sjV^c+2hvPxEjv GSOWmj{ABO| literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/search2.gif b/WebHelpDocs/2601B-PULSE/search2.gif new file mode 100644 index 0000000000000000000000000000000000000000..255913d89069a3ba9911a3cb96ecba2fa0f60334 GIT binary patch literal 1041 zcmZ?wbhEHbbYhTZ_|5A zd|Gn4QB#mlp<#jAnMwMw$80PXEMs8QDSkC2l7TUx*@B-bVwUlfgL7HErJi$|UhpQ&eo5=!wz?;Y&iN8j0?>^77WUob_3{+20hJHYZ$+k6cLf4d>RWrR4l$d;=P@nsrb%o-|sVaipb!RHyr|zF|vP?(vmO{+F zD$(h6zPpTFu1#&V>Up!%A@43vWwjlTjbdZ(iOJgWc?))Yetu!G_k6#-yS~1@#LUEC F4FHfVW_ z)-|j3GF)|JHPgXgBH4!8Aq&M%s)cfIQ3>86b~9?J)UW^H<@6ooiH|i=8#w{E}(w>P>f6PuiCJP^z~5O;60yPtPtG3itcTW_*2pV{`WX Rb9;AxfB#@R6FUooH2@qFZ{h#| literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/stylesheet.css b/WebHelpDocs/2601B-PULSE/stylesheet.css new file mode 100644 index 0000000..bcc8e1a --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/stylesheet.css @@ -0,0 +1,1450 @@ +.relatedheading +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 10pt; + color: #DFDFDF; + background-color: #336699; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6px; + margin-bottom: 1px; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 6px; + padding-bottom: 6px; + padding-left: 4px; + padding-right: 4px; + border-color: #FFFFFF; + border-right-style: solid; + border-right-width: 1px; + border-right-color: #FFFFFF; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.relateditem +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 9pt; + color: #000000; + background-color: #EAEAEA; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0pt; + margin-bottom: 0pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 4px; + padding-bottom: 4px; + padding-left: 4px; + padding-right: 4px; + border-color: #FFFFFF; + border-right-style: solid; + border-right-width: 1px; + border-right-color: #FFFFFF; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.bodytext +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.superscript +{display: inline; + font-size: 6pt; + color: inherit; + background-color: inherit; + vertical-align: 20%; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +.iclspacing +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.codetable +{font-family: "Courier New"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 3pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.tablebodytext +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.specialbold +{display: inline; + font-family: "Arial"; + font-weight: bold; + color: #000000; + background-color: inherit; + vertical-align: baseline; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +.monospace +{display: inline; + font-family: "Courier New"; + color: inherit; + background-color: inherit; + vertical-align: baseline; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +.monospaceitalic +{display: inline; + font-family: "Courier New"; + font-style: italic; + color: #000000; + background-color: inherit; + vertical-align: baseline; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +.note +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: #F2FFFF; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0cm; + margin-right: 6pt; + padding-top: 4pt; + padding-bottom: 4pt; + padding-left: 4pt; + padding-right: 4pt; + border-color: #003399; + border-top-style: solid; + border-top-width: 2px; + border-top-color: #003399; + border-bottom-style: double; + border-bottom-width: 2px; + border-bottom-color: #003399; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +ul.listbullet +{list-style-type: Square; + list-style-image: none; + list-style-position: outside; + margin-top: 3pt; + margin-bottom: 0pt; + } +li.listbullet +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 0pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.headingprocedure +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 10pt; + color: #0033CC; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 10pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +ol.listnumber +{list-style-type: Decimal; + list-style-position: outside; + margin-top: 6pt; + margin-bottom: 0pt; + } +li.listnumber +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 0pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.code +{font-family: "Courier New"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.tableheading +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 10pt; + color: #004080; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0pt; + margin-bottom: 2pt; + margin-left: -2pt; + margin-right: -2pt; + padding-top: 6pt; + padding-bottom: 6pt; + padding-left: 6pt; + padding-right: 6pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.tableheadingsmall +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 10pt; + color: #004080; + background-color: #DFDFDF; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0pt; + margin-bottom: 2pt; + margin-left: -2pt; + margin-right: -2pt; + padding-top: 6pt; + padding-bottom: 6pt; + padding-left: 6pt; + padding-right: 6pt; + border-color: #FFFFFF; + border-right-style: solid; + border-right-width: 1px; + border-right-color: #FFFFFF; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.spacing +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.symbols +{display: inline; + font-family: "Symbol"; + color: inherit; + background-color: inherit; + vertical-align: baseline; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +.tablebodytextcenter +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.emphasis +{display: inline; + font-style: italic; + color: inherit; + background-color: inherit; + vertical-align: baseline; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +.magicfigurecenter +{display: block; + font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: smaller; + color: #FFFFFF; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.listcontinue +{display: block; + font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.listcommand +{display: block; + font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.list +{display: block; + font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +ul.listbullet2 +{list-style-type: Square; + list-style-image: none; + list-style-position: outside; + margin-top: 3pt; + margin-bottom: 0pt; + } +li.listbullet2 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 0pt; + margin-left: 24pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.heading2-icl +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 14pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.bodyzero +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.tableheadingwhitetext +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 10pt; + color: #FFFFFF; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0pt; + margin-bottom: 2pt; + margin-left: -2pt; + margin-right: -2pt; + padding-top: 6pt; + padding-bottom: 6pt; + padding-left: 6pt; + padding-right: 6pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.tablebodytextsmall +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.iclsubheading +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: medium; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + border-color: #000000; + border-bottom-style: solid; + border-bottom-width: thin; + border-bottom-color: #000000; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.iclcode +{font-family: "Courier New"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 3pt; + margin-bottom: 3pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.iclbody +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.grayedout +{display: inline; + font-family: "Arial"; + font-size: 10pt; + color: #808080; + background-color: inherit; + vertical-align: baseline; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +ul.tablelistbullet9pt +{list-style-type: Square; + list-style-image: none; + list-style-position: outside; + margin-top: 4pt; + margin-bottom: 0pt; + } +li.tablelistbullet9pt +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 4pt; + margin-bottom: 0pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.subscript +{display: inline; + font-size: 6pt; + color: inherit; + background-color: inherit; + vertical-align: sub; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + } +.warning +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: #FFF0F0; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0cm; + margin-right: 6pt; + padding-top: 4pt; + padding-bottom: 4pt; + padding-left: 4pt; + padding-right: 4pt; + border-color: #FF0000; + border-top-style: solid; + border-top-width: 2px; + border-top-color: #FF0000; + border-bottom-style: double; + border-bottom-width: 2px; + border-bottom-color: #FF0000; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.caution +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 10pt; + color: #000000; + background-color: #FFF2E6; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 6pt; + margin-left: 0pt; + margin-right: 6pt; + padding-top: 4pt; + padding-bottom: 4pt; + padding-left: 4pt; + padding-right: 4pt; + border-color: #FF8000; + border-top-style: solid; + border-top-width: 2px; + border-top-color: #FF8000; + border-bottom-style: double; + border-bottom-width: 2px; + border-bottom-color: #FF8000; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.heading1 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 16pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.heading2 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 14pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.heading3 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 12pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.heading4 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 12pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.heading5 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 12pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.heading6 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 12pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 6pt; + margin-bottom: 3pt; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.indexatoz +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 14pt; + color: #808080; + background-color: #CFCFCF; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 12pt; + margin-bottom: 0pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 6pt; + padding-bottom: 6pt; + padding-left: 6pt; + padding-right: 6pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.indexheading +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 14pt; + color: #004080; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0pt; + margin-bottom: 0pt; + margin-left: 0pt; + margin-right: 0pt; + padding-top: 12pt; + padding-bottom: 6pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0cm; + width: auto; + height: auto; + white-space: normal; + } +.index1 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: bold; + font-size: 8pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0cm; + margin-bottom: 0cm; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 3pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0pt; + width: auto; + height: auto; + white-space: normal; + } +.index2 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 8pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0cm; + margin-bottom: 0cm; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0pt; + width: auto; + height: auto; + white-space: normal; + } +.index3 +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 8pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0cm; + margin-bottom: 0cm; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0pt; + width: auto; + height: auto; + white-space: normal; + } +.indexlink +{font-family: "Arial"; + font-style: italic; + font-variant: normal; + font-weight: normal; + font-size: 8pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0cm; + margin-bottom: 0cm; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 0pt; + width: auto; + height: auto; + white-space: normal; + } +.toc +{font-family: "Arial"; + font-style: normal; + font-variant: normal; + font-weight: normal; + font-size: 8pt; + color: #000000; + background-color: inherit; + word-spacing: normal; + letter-spacing: normal; + vertical-align: baseline; + text-decoration: none; + text-transform: none; + line-height: normal; + margin-top: 0cm; + margin-bottom: 0cm; + margin-left: 0cm; + margin-right: 0cm; + padding-top: 0pt; + padding-bottom: 0pt; + padding-left: 0pt; + padding-right: 0pt; + float: none; + clear: none; + text-align: left; + text-indent: 6pt; + width: auto; + height: auto; + white-space: normal; + } + diff --git a/WebHelpDocs/2601B-PULSE/tab_index.htm b/WebHelpDocs/2601B-PULSE/tab_index.htm new file mode 100644 index 0000000..67dbae2 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/tab_index.htm @@ -0,0 +1,30 @@ + + + + + + + + + + + + Keithley Instruments Inc. + + + + + + + + +
ContentsSearch
+ + \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/tab_search.htm b/WebHelpDocs/2601B-PULSE/tab_search.htm new file mode 100644 index 0000000..8001523 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/tab_search.htm @@ -0,0 +1,30 @@ + + + + + + + + + + + + Keithley Instruments Inc. + + + + + + + + +
ContentsIndex
+ + diff --git a/WebHelpDocs/2601B-PULSE/tab_toc.htm b/WebHelpDocs/2601B-PULSE/tab_toc.htm new file mode 100644 index 0000000..ac8ab3b --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/tab_toc.htm @@ -0,0 +1,30 @@ + + + + + + + + + +Keithley Instruments Inc. + + Keithley Instruments Inc. + + + + + + + + +
IndexSearch
+ + \ No newline at end of file diff --git a/WebHelpDocs/2601B-PULSE/tail.gif b/WebHelpDocs/2601B-PULSE/tail.gif new file mode 100644 index 0000000000000000000000000000000000000000..42068cd874823e2d67a147209b757fc08540681e GIT binary patch literal 926 zcmZ?wbhEHbT+1NM@SOny{xkglU(HYr1bg@Hy?5{4e+HnyC>RZa;U5Azpd0|o3k)31 z4BQ+t9vc=MY~~QwiaD`i;o)`xWv@9N8y6kzmN3q`b7JG-gtHiS$9uuU44Ch!r?Ai?`=6(S7uyZ6?=Ny+S}U;9!v3ZFjxZs0SY=i literal 0 HcmV?d00001 diff --git a/WebHelpDocs/2601B-PULSE/toc.hhc b/WebHelpDocs/2601B-PULSE/toc.hhc new file mode 100644 index 0000000..bf1a544 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/toc.hhc @@ -0,0 +1,15 @@ + + + + + + + + + + + +

    +
+ + diff --git a/WebHelpDocs/2601B-PULSE/toc.xml b/WebHelpDocs/2601B-PULSE/toc.xml new file mode 100644 index 0000000..5b7eb80 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/toc.xml @@ -0,0 +1,581 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/WebHelpDocs/2601B-PULSE/toc_template.htm b/WebHelpDocs/2601B-PULSE/toc_template.htm new file mode 100644 index 0000000..1dccc59 --- /dev/null +++ b/WebHelpDocs/2601B-PULSE/toc_template.htm @@ -0,0 +1,24 @@ + + + + + + + + + + + + + + + + +
+ +
+ +
+ + \ No newline at end of file