Thanks to visit codestin.com
Credit goes to lib.rs

#psi #rv #parapsychology #remoteview #remoteviewing

bin+lib psitool

The 100% free and open-source Remote Viewing toolset

6 releases (breaking)

Uses new Rust 2024

0.6.0 Sep 29, 2025
0.5.0 Sep 29, 2025
0.4.0 Sep 28, 2025
0.3.0 Sep 28, 2025
0.1.0 Sep 27, 2025

#567 in Images

Codestin Search App Codestin Search App Codestin Search App Codestin Search App Codestin Search App

131 downloads per month

GPL-3.0-or-later

61KB
1K SLoC

psitool

psitool is a 100% free and open-source toolset built in Rust to help you practice Remote Viewing and download and maintain target pools, as well as pick a training image.

The main tool is psi-target-pool. Assuming you have a valid config at ~/.psitool.yaml (see Config Format below), and have downloaded target images (see psi-wm-downloader utility help section below), then you can use the main binary to generate a 100% blind remote-viewing target.

Completed targets are stored in ~/.psitool_completed_targets.yaml by default, but you can point at any path. Comment them out if you want to reuse those targets, or pass --reuse-targets as an argument to reuse all of them.

The 100% free and open-source Remote Viewing toolset.

$ psi-target-pool -h The 100% free and open-source Remote Viewing toolset.

Usage: psi-target-pool [OPTIONS]

Options:
  -v, --verbose                        verbose logging (debug logs)
  -q, --quiet                          quiet logging (warn+ logs)
  -r, --reuse-targets                  reuse all targets, even if they're already completed
  -f...                                how much to frontload, none by default (pass -f for 1 level of frontloading, -ff for 2, -fff for 3...)
  -s, --skip-open                      dont open the target after
  -c, --config <CONFIG>                the config with the target pools [default: ~/.psitool.yaml]
  -C, --completed <COMPLETED>          the yaml config with a list of completed targets (used to cache what you RV'd already) [default: ~/.psitool_completed_targets.yaml]
      --cached-hashes <CACHED_HASHES>  the yaml config with a list of cached hashes so it doesn't have to compute them every run [default: ~/.psitool_cached_hashes.yaml]
  -p, --pools <POOLS>                  the named target pool to read from (included unless excluded via label)
  -i, --include-label <INCLUDE_LABEL>  the target pools to read from, including this label
  -x, --exclude-label <EXCLUDE_LABEL>  the target pools to read from, EXCLUDING this label
  -h, --help                           Print help
  -V, --version                        Print version

Basically, if no options are passed, it will use every pool you defined in the config, with every JPEG/JPG/SVG/TARGET in each of their directories. It will process whatever you have in ~/.psitool_completed_targets.yaml and skip the pre-used targets, unless you pass -r or --reuse-targets

The output will look like this when run from the command-line, and then you can press Enter to see the target.

(Use --quiet or -q to suppress info logs)

$ psi-target-pool
[2025-09-29T03:21:55Z] INFO: Selecting from 2 pools, 1418 targets.

Target: R-WR1J-84HF-Q5EVQ3PVR17C8PXS7C
Remote viewer, begin viewing.
Press ENTER when complete.

... <pressed enter> ...

Path: ~/Documents/rv_pools/train/Kampen,_Sculpture_De_Kamper_koe._10-01-2022._(actm.).jpg
YAML meta: ~/Documents/rv_pools/train/Kampen,_Sculpture_De_Kamper_koe._10-01-2022._(actm.).jpg.yaml
Query: sculpture
Description: "Kampen, Sculpture \" De Kamper koe\" Artwork by Jits Bakker."
Datetime: "2022-01-10 12:29:43"
License: CC BY-SA 4.0
Was it a hit ([y]es, [n]o, otherwise not saved/recorded)? y
Score out of 100 (0 to 100 or otherwise not saved/recorded)? 25
Any notes? Press enter to end (or blank to not save anything): saw a horse but thought it was real

[2025-09-28T05:45:42Z] INFO: Succesfully wrote 1 completed targets to ~/.psitool_completed_targets.yaml

Note: I added caching, but it still needs to run at least once on each file and save the cache. But after downloading a bunch of test images then running it once, it will be way faster the next run.

Notice the RVUID provided, R-DB56-29KT-XS94S59E2HMFYZW9GC. This is generated via the uuid5 function, which is non-random and generated using the actual bytes of the target file. The same exact file (bit by bit) will generate the same "RVUID", or Remote Viewing Unique Identifier.

This is like a UUID, except it uses base-32 digits (all digits, most uppercase letters except I/L/O/U since they can be confused with 1/0), and it splits the 128-bits into 3 sections with a static R- prefix.

Basically, as a remote viewer it should be enough to just write R-2DTH-GZW5 as above, but that is just 40-bits and ot the full RVUID. However, all completed targets are saved to the completed config file, and it can find the associated full RVUID if you just provide the short version, like so:

$ psi-rvuid-find R-WR1J-84HF
R-WR1J-84HF-Q5EVQ3PVR17C8PXS7C found at: ~/Documents/rv_pools/train/Kampen,_Sculpture_De_Kamper_koe._10-01-2022._(actm.).jpg

You can always create your own jpg/jpeg/target files and throw them in a directory. This is made so you can maintain your own private target pools as well.

It also supports text files with the .target extension, so you can write out your own target like so:

echo "The workers burying the body of Alexander the Great, where and when he was buried." > ~/Documents/pool_dir/atg.target

For example (I am using the --include-label me as -i me because that selects the one pool I labeled with me):

$ psi-target-pool -i me -q
Target: R-P14S-9E46-JXEE1030TDSB5Y6KJM
Remote viewer, begin viewing.
Press ENTER when complete.

...<pressed enter>...

Path: ~/Documents/rv_pools/personal_pool/foo.bar.target
Target Text:
The Mona Lisa painting, where it is as of 9/2025.

Was it a hit ([y]es, [n]o, otherwise not saved/recorded)? y
Score out of 100 (0 to 100 or otherwise not saved/recorded)? 55
Any notes? Press enter to end (or blank to not save anything):

In this case, it will use the bytes of the text file just as it would the JPG so you still get a normal RVUID that is specific to the exact target text.

Config Format

The config file is by default ~/.psitool.yaml and should look something like this:

target_pools:
  training:
    path: ~/Documents/rv_pools/train
    labels: [train, wiki]
    wiki:
      default_limit: 2000
      queries:
        - query: animal
        - query: building
        - query: landscape
        - query: vehicle
        - query: portrait
        - query: sculpture
        - query: painting
        - query: object
        - query: artifact
        - query: tool
        - query: music
        - query: food
        - query: statue
        - query: historical
          limit: 5000
        - query: event
  training_with_frontloading:
    path: ~/Documents/rv_pools/train_with_fl
    labels: [train, frontload, wiki]
    wiki:
      default_limit: 1000
      queries:
        - query: historical event
          frontloading: ["historical event"]
        - query: natural landscape
          frontloading: ["natural landscape", "more specific frontloading", "even more specific"]
  personal:
    path: ~/Documents/rv_pools/personal_pool
    labels: [me]

This defines all your target pools, keyed by their name.

Above, you see three pools. One is the personal pool with label me, and has a path to a document directory (which will be created if it does not exist when being downloaded to).

The training pool is interesting here because it provides a specification about what it will download from wikimedia if you want to generate all the target pool images to use for training purposes. Each query pattern will ask for 2000 images, unless you put in a custom limit like under "historical" in the above example, which will get 5000 instead of 2000.

It will query for each of those, using the limit provided.

Notice the other pool training_with_frontloading, where each query has a list of frontloading phrases.

These are completely optional, and even if you save frontloading data, you have to request psi-target-pool to output it when remote viewing. By default, it shows none. If you want the first item (most generic frontloading) from the list, pass -f, which might be "historical event" or "natural landscape" as seen above. If you want the next more specific frontloading, pass -ff, and then -fff, and so on. It will only output what you ask for, if it has it.

What this does is just download the data, and save the metadata in the associated $path.jpg.yaml under a key frontloading. You can edit this for any target you have and customize the YAML. This is just a helper for downloading training datasets.

Be aware that the query might not always give you an exact example of what you frontload. For example, if you put "biological" as frontloading for the animal query, this is not exactly correct for the "animal" query which sometimes gives you images like an amulet shaped like a wolf. I would suggest using something more generic, or customize the yaml files manually.

psi-wm-downloader

This handy tool will take a target pool name and download all sorts of RV training data for yourself. Each image will be downloaded sequentially, which is relatively slow but also should be a one-time process, and thus nicer to the wikimedia servers.

You need a valid config at ~/.psitool.yaml (or passed in as -c|--config) that specifies the queries to use to fill the specified target pool.

For example, for the above you would run psi-wm-downloader training

Usage: psi-wm-downloader [OPTIONS] <POOL>

Arguments:
  <POOL>  the target pool to download for

Options:
  -v, --verbose          verbose logging (debug logs)
      --free-only        only download CC0, CC-BY, and PUBLIC DOMAIN so they can be rebundled
  -c, --config <CONFIG>  the config with the target pools [default: ~/.psitool.yaml]
  -l, --limit <LIMIT>    override wiki default_limit
  -h, --help             Print help
  -V, --version          Print version

Users are responsible for reusing images under their correct license terms.

By default, it will download whatever wikimedia gives you. However, you can pass --free-only to skip everything that isn't CC0, CC-BY (not CC-BY-SA/NC/ND), and PUBLIC DOMAIN.

CC-BY requires you (I believe, I am not a lawyer) to redistribute if you give credit to the original artist/owner. The YAML files that are associated with each JPG (same path, but + ".yaml") include that License data provided from wikimedia. You should be able to use that, I think. Again, I'm not a lawyer, but this is my best effort to allow you to download free content and share it. I solely provide this downloader, none of the images.

psi-rvuid-gen

This utility generates RVUID hashes from paths.

Usage: psi-rvuid-gen [OPTIONS] [PATHS]...

Arguments:
  [PATHS]...  paths to hash and determine rvuid

Options:
  -v, --verbose  verbose logging (debug logs)
  -q, --quiet    quiet logging (warn+ logs)
  -h, --help     Print help
  -V, --version  Print version

Example:

$ psi-rvuid-gen ./README.md
./README.md = R-4NJX-Z0BV-E9AAHEDRNBNXT8RRC4

$ psi-rvuid-gen ./README.md src/*
./README.md = R-4NJX-Z0BV-E9AAHEDRNBNXT8RRC4
src/config.rs = R-DG4D-A9VQ-XSFX3AQKW95HKNC32M
src/lib.rs = R-3344-2KR0-ZXEEDBTPPS9RE9MV5R
src/logger.rs = R-Z562-F0JF-NHEVXA5SAYG9G2V928
src/rvuid.rs = R-PHAJ-P5S5-5197V7YXRRWM4TBA30
src/target.rs = R-3BVX-6WZ6-TSB070P33PHWWJ0A2W

psi-rvuid-find

This utility will look for provided RVUIDs. They can be the full version like R-3BVX-6WZ6-TSB070P33PHWWJ0A2W or even just the short version, R-3BVX-6WZ6

Usage: psi-rvuid-find [OPTIONS] [RVUIDS]...

Arguments:
  [RVUIDS]...  the RVUIDs to look for

Options:
  -v, --verbose                        verbose logging (debug logs)
  -q, --quiet                          quiet logging (warn+ logs)
  -D, --find-dupes                     keep searching even if you already found every RVUID (find potential dupes)
  -c, --config <CONFIG>                the config with the target pools (this is where it will look for the RVUID) [default: ~/.psitool.yaml]
      --cached-hashes <CACHED_HASHES>  the yaml config with a list of cached hashes so it doesn't have to compute them every run [default: ~/.psitool_cached_hashes.yaml]
  -h, --help                           Print help
  -V, --version                        Print version

Example:

$ psi-rvuid-find R-BRHR-XGP6-E5BENEWQXDBEXBKN4W R-ZANQ-CJK4-JD969E5TFGATJCX3VW

R-BRHR-XGP6-E5BENEWQXDBEXBKN4W found at: ~/Documents/rv_pools/train/2014_Prowincja_Sjunik,_Klasztor_Tatew_(19).jpg
R-ZANQ-CJK4-JD969E5TFGATJCX3VW found at: ~/Documents/rv_pools/train/2013-Aerial-Mount_of_Olives.jpg

Now works with shortened 40-bit formats (like R-GWVD-CYBT), so you don't have to write everything down):

$ psi-rvuid-find R-GWVD-CYBT R-HN40-R5YJ-PNF8V2M9Y37FKPPEW4
R-GWVD-CYBT-2D9DS3D0FP0A93QH54 found at: ~/Documents/rv_pools/personal_pool/test2.target
R-HN40-R5YJ-PNF8V2M9Y37FKPPEW4 found at: ~/Documents/rv_pools/personal_pool/test1.target

$ echo $?
0

$ psi-rvuid-find R-GWVD-CYBT R-HN40-R5YJ-PNF8V2M9Y37FKPPEW0
R-GWVD-CYBT-2D9DS3D0FP0A93QH54 found at: ~/Documents/rv_pools/personal_pool/test2.target
Error: missing: [Rvuid { uuid: 8d480c17-d2b5-5e8d-8a89-f0cef9dacee0, rvuid: "R-HN40-R5YJ-PNF8V2M9Y37FKPPEW0", missing_bits: false, prefix40: 606799140818 }]

$ echo $?
1

$ psi-rvuid-find R-GWVD-CYBT R-HN40-R5YJ
R-GWVD-CYBT-2D9DS3D0FP0A93QH54 found at: ~/Documents/rv_pools/personal_pool/test2.target
R-HN40-R5YJ-PNF8V2M9Y37FKPPEW4 found at: ~/Documents/rv_pools/personal_pool/test1.target

$ echo $?
0

Roadmap

I'm open to suggestions, so feel free to contact me at psitool #at# protonmail #dot# com

The next obvious feature I'm planning is Associated Remote Viewing functionality.

Dependencies

~10–27MB
~332K SLoC