Fair Housing Guardrail is a tool designed to help housing providers, real estate professionals, and related organizations review compliance of textual content with fair housing and fair lending laws in the United States, specifically the federal Fair Housing Act and the Equal Credit Opportunity Act. By leveraging a combination of stop list and fine-tuned BERT-based classifier which offers low latency and ease of fine-tuning compared to LLMs, Fair Housing Guardrail is intended to identify content that may potentially violate these laws, allowing users to make necessary adjustments to help maintain compliance.
For a comprehensive overview of Fair Housing Guardrail, including its features, usage instructions, and implementation details, please visit our blog
In use cases which use an LLM, we recommend using Fair Housing Guardrail in combination with a fair housing specific prompt as we found that it yielded better coverage in violation detection and prevention. Refer to the ‘Prompt Engineering’ section here for more details.
Compliance Detection: Fair Housing Guardrail utilizes advanced natural language processing techniques to identify content that may violate fair housing and fair lending laws.
Customizable Stop List: The tool demonstrates incorporating a curated list of terms and phrases commonly associated with discriminatory language, helping to flag potentially non-compliant content. Users may modify the sample stop list to add phrases relevant for their scenario.
Customizable BERT-based Classifier: Fair Housing Guardrail employs a fine-tuned BERT-based classifier to analyze text and determine whether it aligns with fair housing and fair lending regulations. Users can adapt this framework to a different domain by providing their specific training data with compliant and non-compliant examples.
Fair Housing Policy: Specifically, the model was trained to address the risk of illegal “steering” in real estate. In the traditional brick and mortar sense, this is when a real estate agent takes into account the legally-protected characteristics of their client when determining which listings to show them. A well publicized example of this was documented in a three-year investigation by Newsday, published in 2019. Extensive fair housing testing or “secret shopping” of real estate agents on Long Island, New York was conducted, finding that many would direct different clients to different neighborhoods, depending on the race or ethnicity of the client, and the racial and ethnic demographics of the neighborhood.
Fine-tuned model and labeled dataset: Refer to the ‘Contact Us’ section to request this.
Fair Housing Guardrail works by taking input text and running it through both the stop list and the fine-tuned BERT-based classifier. If the text contains any flagged terms from the stop list or if the classifier determines it to be non-compliant with the fair housing and fair lending guidelines that it was trained on, the tool will label the content accordingly, providing an opportunity to review and revise the content as necessary.
Note that this project was designed to provide low latency, standalone and easy-to-tune guardrails for Fair Housing and Fair Lending compliance of conversational or text based experiences. The fine-tuned model (provided upon request) is an ongoing work in progress and we will be iteratively improving its accuracy. We invite you - the developers and AI practitioners - to help us identify gaps, submit improvements via pull requests as well as share your feedback directly with us via email at [email protected].
After cloning the repo to a local directory, you can install the necessary dependencies with poetry.
Make sure you have Poetry installed. If not, you can install it by following the instructions at https://python-poetry.org/docs/#installation.
Navigate to the project directory that you cloned.
Run the following command to install the project dependencies using Poetry:
poetry install
The project includes an examples/
folder that contains two Jupyter notebooks:
train_model: This notebook uses the sample train-config.yaml
file to load train and test datasets. Then, it runs training and plots the training and validation losses and saves the pretrained model.
test_model: This notebook uses the sample test-config.yaml
file to load a test dataset. Ensure that paths to dataset and trained model are updated in test-config.yaml. Then, it runs predictions and returns the results.
See the Contributing file for instructions on how to submit a PR.
See the License file.
Fair Housing Guardrail is provided for informational purposes only and should not be considered legal advice. We recognize that users will interpret fair housing and fair lending requirements based on their own understanding and risk appetite, and are responsible for ensuring compliance with all applicable laws and regulations.
If you are interested in obtaining the training data and/or trained model, kindly contact us at [email protected]. In your message, provide a brief paragraph outlining your intended use case and how you plan to utilize both the model and dataset.