construct-tracker


Nameconstruct-tracker JSON
Version 1.0.14 PyPI version JSON
download
home_pagehttps://github.com/danielmlow/construct-tracker
SummaryTrack and measure constructs, concepts or categories in text documents.
upload_time2025-01-21 22:05:22
maintainerDaniel M. Low
docs_urlNone
authorDaniel M. Low
requires_python<3.12,>=3.9
licenseApache-2.0
keywords lexicon concept classification nlp embeddings similarity zero shot construct category social sciences text
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            [![Build](https://github.com/danielmlow/construct-tracker/actions/workflows/test.yaml/badge.svg?branch=main)](https://github.com/danielmlow/construct-tracker/actions/workflows/test.yaml?query=branch%3Amain)
[![codecov](https://codecov.io/gh/danielmlow/construct-tracker/graph/badge.svg?token=9S8WY128PO)](https://codecov.io/gh/danielmlow/construct-tracker)
[![Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json)](https://github.com/astral-sh/ruff)

[![PyPI](https://img.shields.io/pypi/v/construct-tracker.svg)](https://pypi.org/project/construct-tracker/)
[![Python Version](https://img.shields.io/pypi/pyversions/construct-tracker)](https://pypi.org/project/construct-tracker)
[![License](https://img.shields.io/pypi/l/construct-tracker)](https://opensource.org/licenses/Apache-2.0)

<!-- [![pages](https://img.shields.io/badge/api-docs-blue)](https://sensein.github.io/construct-tracker) -->

# construct-tracker
Track and measure constructs, concepts or categories in text documents. Build interpretable lexicon models quickly by using LLMs. Built on top of the OpenRouterAI package so you can use most Generative AI models.

## Why build lexicons?

They can be used to build models that are:

- **interpretable**: understand why the model outputs a given score, which can help avoid biases and guarantee the model will detect certain phrases (important for high-risk scenarios to use in tandem with LLMs)
- **lightweight**: no GPU needed (unlike LLMs)
- **private and free**: you can run on your local computer instead of submitting to a cloud API (OpenAI) which may not be secure
- **have high content validity**: measure what you actually want to measure (unlike existing lexicons or models that measure something only slightly related)

<br>

# If you use, please cite
Low DM, Rankin O, Coppersmith DDL, Bentley KH, Nock MK, Ghosh SS (2024). Using Generative AI to create lexicons for interpretable text models with high content validity. PsyarXiv.

<br>

# Installation

```bash
pip install construct-tracker
```

<br>

# Measure 49 suicide risk factors in text data

<img src="docs/images/suicide_risk_lexicon.png" alt="Highlight matches" width="900"/>

**Tutorial** [![Open in Google Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/danielmlow/construct-tracker/blob/main/tutorials/suicide_risk_lexicon.ipynb)

We have created a lexicon with 49 risk factors for suicidal thoughts and behaviors (plus one construct for kinship) validated by clinicians who are experts in suicide research.

```python
from construct_tracker import lexicon

srl = lexicon.load_lexicon(name = 'srl_v1-0') # Load lexicon

documents = [
	"I've been thinking about ending it all. I've been cutting. I just don't want to wake up.",
	"I've been feeling all alone. No one cares about me. I've been hospitalized multiple times. I just want out. I'm pretty hopeless"
             ]

# Extract
counts, matches_by_construct, matches_doc2construct, matches_construct2doc = srl.extract(documents, normalize = False)

counts
```
<img src="docs/images/extract_suicide_risk_lexicon.png" alt="Highlight matches" width="900"/>

<!-- lexicon_dict = srl.to_dict()
features, documents_tokenized, lexicon_dict_final_order, cosine_similarities = cts.measure(
    lexicon_dict,
    documents_subset,
    )

<!-- <img src="docs/images/srl_cts_scores.png" alt="Construct-text similarity of Suicide Risk Lexicon" width="700"/> -->

You can also access the Suicide Risk Lexicon in csv and json formats:
- https://github.com/danielmlow/construct-tracker/blob/main/src/construct_tracker/data/lexicons/suicide_risk_lexicon_v1-0/suicide_risk_lexicon_validated_24-08-02T21-27-35.csv
- https://github.com/danielmlow/construct-tracker/blob/main/src/construct_tracker/data/lexicons/suicide_risk_lexicon_v1-0/suicide_risk_lexicon_validated_24-08-02T21-27-35.json


<br>



# Create your own lexicon using generative AI

[![Open in Google Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/danielmlow/construct-tracker/blob/main/tutorials/construct_tracker.ipynb)

## Create a lexicon: keywords prototypically associated to a construct

We want to know if these documents contain mentions of certain construct "insight"

```python
documents = [
 	"Every time I speak with my cousin Bob, I have great moments of clarity and wisdom", # mention of insight
 	"He meditates a lot, but he's not super smart" # related to mindfulness, only somewhat related to insight
	"He is too competitive"] #not very related
```

Choose model [here](https://docs.litellm.ai/docs/providers) and obtain an API key from that provider. Cohere offers a free trial API key, 5 requests per minute. I'm going to choose GPT-4o:

```python
os.environ["api_key"]  = 'YOUR_OPENAI_API_KEY' # This one might work for free models if no submissions have been tested:  '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'
model = 'gpt-4o'
```

Two lines of code to create a lexicon
```python
l = lexicon.Lexicon()         # Initialize lexicon
l.add('Insight', section = 'tokens', value = 'create', source = model)
```

See results:
```python
print(l.constructs['Insight']['tokens'])
```
```
['acuity', 'acumen', 'analysis', 'apprehension', 'awareness', 'clarity', 'comprehension', 'contemplation', 'depth', 'discernment', 'enlightenment', 'epiphany', 'foresight', 'grasp', 'illumination', 'insightfulness', 'interpretation', 'introspection', 'intuition', 'meditation', 'perception', 'perceptiveness', 'perspicacity', 'profoundness', 'realization', 'recognition', 'reflection', 'revelation', 'shrewdness', 'thoughtfulness', 'understanding', 'vision', 'wisdom']
```

We'll repeat for other constructs ("Mindfulness", "Compassion"). Now count whether tokens appear in document:

```python
feature_vectors, matches_counter_d, matches_per_doc, matches_per_construct  = lexicon.extract(
	documents,
	l.constructs,
	normalize = False)

display(feature_vectors)
```

<img src="docs/images/counts.png" alt="Lexicon counts" width="700"/>

<!-- ```
|   Insight |   word_count |
|----------:|-------------:|
|         0 |            4 |
|         2 |           17 |
|         0 |            8 |
``` -->

This traditional approach is perfectly interpretable. The first document contains three matches related to insight. Let's see which ones with `highlight_matches()`:


```python
lexicon.highlight_matches(documents, 'Insight', matches_construct2doc, max_matches = 1)
```


<img src="docs/images/matches_insight.png" alt="Highlight matches" width="500"/>


<!-- ```python
print(matches_per_doc)
{0: {'Insight': (0, [])},
 1: {'Insight': (2, ['clarity', 'wisdom'])},
 2: {'Insight': (0, [])}}
``` -->
<br><br>



<!-- ## 2. Construct-text similarity (CTS): finding similar phrases to tokens in your lexicon

### Like Ctrl+F on steroids!
Lexicons may miss relevant words if not contained in the lexicon (it only counts exact matches). Embeddings can find semantically similar tokens. CTS will scan the document and return how similar is the most related phrase to any word in the lexicon.

<!-- magick -density 300 docs/images/cts.pdf -background white -alpha remove -quality 100 docs/images/cts.png -->
<!-- <img src="docs/images/cts.png" alt="Construct-text similarity" width="650"/> -->

<!-- It will vectorize lexicon tokens and document tokens (e.g., phrases) into embeddings (quantitivae vector representing aspects of meaning). Then it will compute the similarity between both sets of tokens and return the maximum similarity as its score for the document.  -->
<!--

```python
lexicon_dict = my_lexicon.to_dict()

features, documents_tokenized, lexicon_dict_final_order, cosine_similarities = cts.measure(
    lexicon_dict,
    documents,
    )

display(features)
```
<img src="docs/images/cts_scores.png" alt="Construct-text similarity" width="700"/>

So we see that even though compassion did not find an exact match it had some relationship to the first two documents.  -->



<!-- You can also sum the exact counts with the similarities for more fine-grained scores.

<img src="docs/images/cts_scores_sum.png" alt="Construct-text similarity" width="700"/> -->

We provide many features to add/remove tokens, generate definitions, validate with human ratings, and much more (see `tutorials/construct_tracker.ipynb`) [![Open in Google Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/danielmlow/construct-tracker/blob/main/tutorials/construct_tracker.ipynb)

<br>

# Structure of the `lexicon.Lexicon()` object

```python
# Save general info on the lexicon
my_lexicon = lexicon.Lexicon()			# Initialize lexicon
my_lexicon.name = 'Insight'		# Set lexicon name
my_lexicon.description = 'Insight lexicon with constructs related to insight, mindfulness, and compassion'
my_lexicon.creator = 'DML' 				# your name or initials for transparency in logging who made changes
my_lexicon.version = '1.0'				# Set version. Over time, others may modify your lexicon, so good to keep track. MAJOR.MINOR. (e.g., MAJOR: new constructs or big changes to a construct, Minor: small changes to a construct)

# Each construct is a dict. You can save a lot of metadata depending on what you provide for each construct, for instance:
print(my_lexicon.constructs)
{
 'Insight': {
	'variable_name': 'insight', # a name that is not sensitive to case with no spaces
	'prompt_name': 'insight',
	'domain': 'psychology', 	 # to guide Gen AI model as to sense of the construct (depression has different senses in psychology, geology, and economics)
	'examples': ['clarity', 'enlightenment', 'wise'], # to guide Gen AI model
	'definition': "the clarity of understanding of one's thoughts, feelings and behavior", # can be used in prompt and/or human validation
	'definition_references': 'Grant, A. M., Franklin, J., & Langford, P. (2002). The self-reflection and insight scale: A new measure of private self-consciousness. Social Behavior and Personality: an international journal, 30(8), 821-835.',
	'tokens': ['acknowledgment',
	'acuity',
	'acumen',
	'analytical',
	'astute',
	'awareness',
	'clarity',
	...],
	'tokens_lemmatized': [], # when counting you can lemmatize all tokens for better results
	'remove': [], #which tokens to remove
	'tokens_metadata': {'gpt-4o-2024-05-13, temperature-0, ...': {
								'action': 'create',
								'tokens': [...],
								'prompt': 'Provide many single words and some short phrases ...',
								'time_elapsed': 14.21},
						{'gpt-4o-2024-05-13, temperature-1, ...': { ... }},
						}
	},
'Mindfulness': {...},
'Compassion': {...},
}
```


<!-- # Other features -->
<!-- TODO -->


<!-- # Identify constructs with Generative AI models

```python
prompt_template_with_definitions = """Classify the text into one or more of the following {context} categories with their corresponding definitions:\n\n{categories}

Provide a score (between 0 and 1) as to whether the text clearly mentions the category and an explanation (words or phrases from the text that are very prototypical expressions of the category).
Text:
{text}

Structure your response in the following JSON format (no extra text):
{{'category_A': [[score], [words, phrases]], 'category_B': [[score], [words, phrases]], ...}}

JSON:
"""

categories_with_definitions = {'desire to escape': 'wanting to escape emotional pain',
              'suicidal ideation': "desire of not wanting to live",
              'anger': "negative high arousal with irritability and anger",
              'loneliness': "aversive state experienced when a discrepancy exists between the interpersonal relationships one wishes to have and those that one perceives they currently have. The perception that one's social relationships are not living up to some expectation",
              }

# indent dict one line per entry
categories_with_definitions = '\n'.join([f"{key}: {value}" for key, value in categories_with_definitions.items()])

# Insert into prompt
prompt_with_definitions = prompt_template_with_definitions.format(context = '', # I change to prompt_template_with_definitions
              categories = categories_with_definitions,
              text= text
              )


print('Prompt:')
print(prompt_with_definitions)
``` -->

# Contributing
<!-- TODO -->

See `docs/contributing.md`

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/danielmlow/construct-tracker",
    "name": "construct-tracker",
    "maintainer": "Daniel M. Low",
    "docs_url": null,
    "requires_python": "<3.12,>=3.9",
    "maintainer_email": "daniel.m.low@gmail.com",
    "keywords": "lexicon, concept, classification, NLP, embeddings, similarity, zero shot, construct, category, social sciences, text",
    "author": "Daniel M. Low",
    "author_email": "daniel.m.low@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/35/2e/657c729af89af554732126cb981e91c70bc7083cae4723b180a3486b8b8b/construct_tracker-1.0.14.tar.gz",
    "platform": null,
    "description": "[![Build](https://github.com/danielmlow/construct-tracker/actions/workflows/test.yaml/badge.svg?branch=main)](https://github.com/danielmlow/construct-tracker/actions/workflows/test.yaml?query=branch%3Amain)\n[![codecov](https://codecov.io/gh/danielmlow/construct-tracker/graph/badge.svg?token=9S8WY128PO)](https://codecov.io/gh/danielmlow/construct-tracker)\n[![Ruff](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json)](https://github.com/astral-sh/ruff)\n\n[![PyPI](https://img.shields.io/pypi/v/construct-tracker.svg)](https://pypi.org/project/construct-tracker/)\n[![Python Version](https://img.shields.io/pypi/pyversions/construct-tracker)](https://pypi.org/project/construct-tracker)\n[![License](https://img.shields.io/pypi/l/construct-tracker)](https://opensource.org/licenses/Apache-2.0)\n\n<!-- [![pages](https://img.shields.io/badge/api-docs-blue)](https://sensein.github.io/construct-tracker) -->\n\n# construct-tracker\nTrack and measure constructs, concepts or categories in text documents. Build interpretable lexicon models quickly by using LLMs. Built on top of the OpenRouterAI package so you can use most Generative AI models.\n\n## Why build lexicons?\n\nThey can be used to build models that are:\n\n- **interpretable**: understand why the model outputs a given score, which can help avoid biases and guarantee the model will detect certain phrases (important for high-risk scenarios to use in tandem with LLMs)\n- **lightweight**: no GPU needed (unlike LLMs)\n- **private and free**: you can run on your local computer instead of submitting to a cloud API (OpenAI) which may not be secure\n- **have high content validity**: measure what you actually want to measure (unlike existing lexicons or models that measure something only slightly related)\n\n<br>\n\n# If you use, please cite\nLow DM, Rankin O, Coppersmith DDL, Bentley KH, Nock MK, Ghosh SS (2024). Using Generative AI to create lexicons for interpretable text models with high content validity. PsyarXiv.\n\n<br>\n\n# Installation\n\n```bash\npip install construct-tracker\n```\n\n<br>\n\n# Measure 49 suicide risk factors in text data\n\n<img src=\"docs/images/suicide_risk_lexicon.png\" alt=\"Highlight matches\" width=\"900\"/>\n\n**Tutorial** [![Open in Google Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/danielmlow/construct-tracker/blob/main/tutorials/suicide_risk_lexicon.ipynb)\n\nWe have created a lexicon with 49 risk factors for suicidal thoughts and behaviors (plus one construct for kinship) validated by clinicians who are experts in suicide research.\n\n```python\nfrom construct_tracker import lexicon\n\nsrl = lexicon.load_lexicon(name = 'srl_v1-0') # Load lexicon\n\ndocuments = [\n\t\"I've been thinking about ending it all. I've been cutting. I just don't want to wake up.\",\n\t\"I've been feeling all alone. No one cares about me. I've been hospitalized multiple times. I just want out. I'm pretty hopeless\"\n             ]\n\n# Extract\ncounts, matches_by_construct, matches_doc2construct, matches_construct2doc = srl.extract(documents, normalize = False)\n\ncounts\n```\n<img src=\"docs/images/extract_suicide_risk_lexicon.png\" alt=\"Highlight matches\" width=\"900\"/>\n\n<!-- lexicon_dict = srl.to_dict()\nfeatures, documents_tokenized, lexicon_dict_final_order, cosine_similarities = cts.measure(\n    lexicon_dict,\n    documents_subset,\n    )\n\n<!-- <img src=\"docs/images/srl_cts_scores.png\" alt=\"Construct-text similarity of Suicide Risk Lexicon\" width=\"700\"/> -->\n\nYou can also access the Suicide Risk Lexicon in csv and json formats:\n- https://github.com/danielmlow/construct-tracker/blob/main/src/construct_tracker/data/lexicons/suicide_risk_lexicon_v1-0/suicide_risk_lexicon_validated_24-08-02T21-27-35.csv\n- https://github.com/danielmlow/construct-tracker/blob/main/src/construct_tracker/data/lexicons/suicide_risk_lexicon_v1-0/suicide_risk_lexicon_validated_24-08-02T21-27-35.json\n\n\n<br>\n\n\n\n# Create your own lexicon using generative AI\n\n[![Open in Google Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/danielmlow/construct-tracker/blob/main/tutorials/construct_tracker.ipynb)\n\n## Create a lexicon: keywords prototypically associated to a construct\n\nWe want to know if these documents contain mentions of certain construct \"insight\"\n\n```python\ndocuments = [\n \t\"Every time I speak with my cousin Bob, I have great moments of clarity and wisdom\", # mention of insight\n \t\"He meditates a lot, but he's not super smart\" # related to mindfulness, only somewhat related to insight\n\t\"He is too competitive\"] #not very related\n```\n\nChoose model [here](https://docs.litellm.ai/docs/providers) and obtain an API key from that provider. Cohere offers a free trial API key, 5 requests per minute. I'm going to choose GPT-4o:\n\n```python\nos.environ[\"api_key\"]  = 'YOUR_OPENAI_API_KEY' # This one might work for free models if no submissions have been tested:  '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'\nmodel = 'gpt-4o'\n```\n\nTwo lines of code to create a lexicon\n```python\nl = lexicon.Lexicon()         # Initialize lexicon\nl.add('Insight', section = 'tokens', value = 'create', source = model)\n```\n\nSee results:\n```python\nprint(l.constructs['Insight']['tokens'])\n```\n```\n['acuity', 'acumen', 'analysis', 'apprehension', 'awareness', 'clarity', 'comprehension', 'contemplation', 'depth', 'discernment', 'enlightenment', 'epiphany', 'foresight', 'grasp', 'illumination', 'insightfulness', 'interpretation', 'introspection', 'intuition', 'meditation', 'perception', 'perceptiveness', 'perspicacity', 'profoundness', 'realization', 'recognition', 'reflection', 'revelation', 'shrewdness', 'thoughtfulness', 'understanding', 'vision', 'wisdom']\n```\n\nWe'll repeat for other constructs (\"Mindfulness\", \"Compassion\"). Now count whether tokens appear in document:\n\n```python\nfeature_vectors, matches_counter_d, matches_per_doc, matches_per_construct  = lexicon.extract(\n\tdocuments,\n\tl.constructs,\n\tnormalize = False)\n\ndisplay(feature_vectors)\n```\n\n<img src=\"docs/images/counts.png\" alt=\"Lexicon counts\" width=\"700\"/>\n\n<!-- ```\n|   Insight |   word_count |\n|----------:|-------------:|\n|         0 |            4 |\n|         2 |           17 |\n|         0 |            8 |\n``` -->\n\nThis traditional approach is perfectly interpretable. The first document contains three matches related to insight. Let's see which ones with `highlight_matches()`:\n\n\n```python\nlexicon.highlight_matches(documents, 'Insight', matches_construct2doc, max_matches = 1)\n```\n\n\n<img src=\"docs/images/matches_insight.png\" alt=\"Highlight matches\" width=\"500\"/>\n\n\n<!-- ```python\nprint(matches_per_doc)\n{0: {'Insight': (0, [])},\n 1: {'Insight': (2, ['clarity', 'wisdom'])},\n 2: {'Insight': (0, [])}}\n``` -->\n<br><br>\n\n\n\n<!-- ## 2. Construct-text similarity (CTS): finding similar phrases to tokens in your lexicon\n\n### Like Ctrl+F on steroids!\nLexicons may miss relevant words if not contained in the lexicon (it only counts exact matches). Embeddings can find semantically similar tokens. CTS will scan the document and return how similar is the most related phrase to any word in the lexicon.\n\n<!-- magick -density 300 docs/images/cts.pdf -background white -alpha remove -quality 100 docs/images/cts.png -->\n<!-- <img src=\"docs/images/cts.png\" alt=\"Construct-text similarity\" width=\"650\"/> -->\n\n<!-- It will vectorize lexicon tokens and document tokens (e.g., phrases) into embeddings (quantitivae vector representing aspects of meaning). Then it will compute the similarity between both sets of tokens and return the maximum similarity as its score for the document.  -->\n<!--\n\n```python\nlexicon_dict = my_lexicon.to_dict()\n\nfeatures, documents_tokenized, lexicon_dict_final_order, cosine_similarities = cts.measure(\n    lexicon_dict,\n    documents,\n    )\n\ndisplay(features)\n```\n<img src=\"docs/images/cts_scores.png\" alt=\"Construct-text similarity\" width=\"700\"/>\n\nSo we see that even though compassion did not find an exact match it had some relationship to the first two documents.  -->\n\n\n\n<!-- You can also sum the exact counts with the similarities for more fine-grained scores.\n\n<img src=\"docs/images/cts_scores_sum.png\" alt=\"Construct-text similarity\" width=\"700\"/> -->\n\nWe provide many features to add/remove tokens, generate definitions, validate with human ratings, and much more (see `tutorials/construct_tracker.ipynb`) [![Open in Google Colab](https://colab.research.google.com/assets/colab-badge.svg)](https://colab.research.google.com/github/danielmlow/construct-tracker/blob/main/tutorials/construct_tracker.ipynb)\n\n<br>\n\n# Structure of the `lexicon.Lexicon()` object\n\n```python\n# Save general info on the lexicon\nmy_lexicon = lexicon.Lexicon()\t\t\t# Initialize lexicon\nmy_lexicon.name = 'Insight'\t\t# Set lexicon name\nmy_lexicon.description = 'Insight lexicon with constructs related to insight, mindfulness, and compassion'\nmy_lexicon.creator = 'DML' \t\t\t\t# your name or initials for transparency in logging who made changes\nmy_lexicon.version = '1.0'\t\t\t\t# Set version. Over time, others may modify your lexicon, so good to keep track. MAJOR.MINOR. (e.g., MAJOR: new constructs or big changes to a construct, Minor: small changes to a construct)\n\n# Each construct is a dict. You can save a lot of metadata depending on what you provide for each construct, for instance:\nprint(my_lexicon.constructs)\n{\n 'Insight': {\n\t'variable_name': 'insight', # a name that is not sensitive to case with no spaces\n\t'prompt_name': 'insight',\n\t'domain': 'psychology', \t # to guide Gen AI model as to sense of the construct (depression has different senses in psychology, geology, and economics)\n\t'examples': ['clarity', 'enlightenment', 'wise'], # to guide Gen AI model\n\t'definition': \"the clarity of understanding of one's thoughts, feelings and behavior\", # can be used in prompt and/or human validation\n\t'definition_references': 'Grant, A. M., Franklin, J., & Langford, P. (2002). The self-reflection and insight scale: A new measure of private self-consciousness. Social Behavior and Personality: an international journal, 30(8), 821-835.',\n\t'tokens': ['acknowledgment',\n\t'acuity',\n\t'acumen',\n\t'analytical',\n\t'astute',\n\t'awareness',\n\t'clarity',\n\t...],\n\t'tokens_lemmatized': [], # when counting you can lemmatize all tokens for better results\n\t'remove': [], #which tokens to remove\n\t'tokens_metadata': {'gpt-4o-2024-05-13, temperature-0, ...': {\n\t\t\t\t\t\t\t\t'action': 'create',\n\t\t\t\t\t\t\t\t'tokens': [...],\n\t\t\t\t\t\t\t\t'prompt': 'Provide many single words and some short phrases ...',\n\t\t\t\t\t\t\t\t'time_elapsed': 14.21},\n\t\t\t\t\t\t{'gpt-4o-2024-05-13, temperature-1, ...': { ... }},\n\t\t\t\t\t\t}\n\t},\n'Mindfulness': {...},\n'Compassion': {...},\n}\n```\n\n\n<!-- # Other features -->\n<!-- TODO -->\n\n\n<!-- # Identify constructs with Generative AI models\n\n```python\nprompt_template_with_definitions = \"\"\"Classify the text into one or more of the following {context} categories with their corresponding definitions:\\n\\n{categories}\n\nProvide a score (between 0 and 1) as to whether the text clearly mentions the category and an explanation (words or phrases from the text that are very prototypical expressions of the category).\nText:\n{text}\n\nStructure your response in the following JSON format (no extra text):\n{{'category_A': [[score], [words, phrases]], 'category_B': [[score], [words, phrases]], ...}}\n\nJSON:\n\"\"\"\n\ncategories_with_definitions = {'desire to escape': 'wanting to escape emotional pain',\n              'suicidal ideation': \"desire of not wanting to live\",\n              'anger': \"negative high arousal with irritability and anger\",\n              'loneliness': \"aversive state experienced when a discrepancy exists between the interpersonal relationships one wishes to have and those that one perceives they currently have. The perception that one's social relationships are not living up to some expectation\",\n              }\n\n# indent dict one line per entry\ncategories_with_definitions = '\\n'.join([f\"{key}: {value}\" for key, value in categories_with_definitions.items()])\n\n# Insert into prompt\nprompt_with_definitions = prompt_template_with_definitions.format(context = '', # I change to prompt_template_with_definitions\n              categories = categories_with_definitions,\n              text= text\n              )\n\n\nprint('Prompt:')\nprint(prompt_with_definitions)\n``` -->\n\n# Contributing\n<!-- TODO -->\n\nSee `docs/contributing.md`\n",
    "bugtrack_url": null,
    "license": "Apache-2.0",
    "summary": "Track and measure constructs, concepts or categories in text documents.",
    "version": "1.0.14",
    "project_urls": {
        "Documentation": "https://danielmlow.github.io/construct-tracker/",
        "Homepage": "https://github.com/danielmlow/construct-tracker",
        "Repository": "https://github.com/danielmlow/construct-tracker"
    },
    "split_keywords": [
        "lexicon",
        " concept",
        " classification",
        " nlp",
        " embeddings",
        " similarity",
        " zero shot",
        " construct",
        " category",
        " social sciences",
        " text"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "fc378e572abda1cbbe4d7a5f3efb90d182c3f1227b664486414ac76d02442325",
                "md5": "d6f11bd5b6fd9917596e36116b49633a",
                "sha256": "a13db3e2a86b5875401e8e419d993a1c27fc7d4549cc71b2cb77a536bbe6d483"
            },
            "downloads": -1,
            "filename": "construct_tracker-1.0.14-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "d6f11bd5b6fd9917596e36116b49633a",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": "<3.12,>=3.9",
            "size": 12721032,
            "upload_time": "2025-01-21T22:05:19",
            "upload_time_iso_8601": "2025-01-21T22:05:19.323650Z",
            "url": "https://files.pythonhosted.org/packages/fc/37/8e572abda1cbbe4d7a5f3efb90d182c3f1227b664486414ac76d02442325/construct_tracker-1.0.14-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "352e657c729af89af554732126cb981e91c70bc7083cae4723b180a3486b8b8b",
                "md5": "3f2d882fb9b925aa0b58a58d47f80aae",
                "sha256": "7a4b582b56e16e7a4219c0fcb6fbc8c425d3acb15df410ff9cf4ad5d414bcc49"
            },
            "downloads": -1,
            "filename": "construct_tracker-1.0.14.tar.gz",
            "has_sig": false,
            "md5_digest": "3f2d882fb9b925aa0b58a58d47f80aae",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": "<3.12,>=3.9",
            "size": 12585284,
            "upload_time": "2025-01-21T22:05:22",
            "upload_time_iso_8601": "2025-01-21T22:05:22.925699Z",
            "url": "https://files.pythonhosted.org/packages/35/2e/657c729af89af554732126cb981e91c70bc7083cae4723b180a3486b8b8b/construct_tracker-1.0.14.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-21 22:05:22",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "danielmlow",
    "github_project": "construct-tracker",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "tox": true,
    "lcname": "construct-tracker"
}
        
Elapsed time: 1.20968s