Skip to content

Latest commit

 

History

History
234 lines (209 loc) · 14.7 KB

README.md

File metadata and controls

234 lines (209 loc) · 14.7 KB

Hi 👋, I'm Sergey Makarov

sergey030520

sergey030520

Languages and Tools:

cplusplus git Cmake

search_engine

Оглавление

  1. Описание

  2. Инструкция по подключению библиотек

  3. Сборка проекта и тестирование

  4. Инструкция по сборке проекта

    1. Конфигурационный файл поискового движка

    2. Файл пользовательских запросов

    3. Файл ответов на пользовательские запросы

  5. Пример работы поискового движка

Описание

Разработанный поисковой движок представляет из себя консольное приложение (исполняемый файл, запускаемый на любом сервере или компьютере), осуществляющий поиск и имеющий возможность настройки через файлы формата JSON. Применённые в нём решения можно впоследствии встроить в поисковый движок работающий на веб.

Принципы работы поискового движка следующие:

  1. В конфигурационном файле перед запуском приложения задаются названия файлов, по которым движок будет осуществлять поиск.
  2. Поисковый движок должен самостоятельно обходить все файлы и индексировать их так, чтобы потом по любому поисковому запросу находить наиболее релевантные документы.
  3. Пользователь задаёт запрос через JSON-файл requests.json. Запрос — это набор слов, по которым нужно найти документы.
  4. Запрос трансформируется в список слов.
  5. В индексе ищутся те документы, на которых встречаются все эти слова.
  6. Результаты поиска ранжируются, сортируются и отдаются пользователю, максимальное количество возможных документов в ответе задаётся в конфигурационном файле.
  7. В конце программа формирует файл answers.json, в который записывает результаты поиска.

Инструкция по подключению библиотек

В проекте уже сгенированны два файла конфигурации:

  1. CMakeLists.txt — основной файл конфигурации и подключает библиотеку для тестированиях программы googletest и библиотеку nlohmann/json для работы с Json файлами;
  2. CMakeLists.txt — файл конфигурации, который подключает классы программы.

Сборка проекта и тестирование

Данный проект был собран и протестирован с помощью таких компиляторов, как MSVC 2019 и GCC. Программа разработана на языке C++ 17 стандарта и поддерживает следующие операционные системы:

  • Windows 10
  • Windows 11
  • Ubuntu 22.10

Инструкция по сборке проекта

Сборка проекта производится с помощью инструмента CMake. В терминале компьютера необходимо прописать следующие команды:

cmake --build . --config Release --target main

Конфигурационный файл поискового движка

Пример описания конфигурационного файла config.json:

{
  "config": {
    "name": "SearchEngine",
    "version": "0.10",
    "max_responses": 5
  },
  "files": [
    "../resorces/file001.txt",
    "../resorces/file002.txt",
    "../resorces/file003.txt",
    "../resorces/file004.txt"
  ]
}

Подробнее разберём каждое поле файла config.json:

  • config — общая информация, без которой приложение не запускается. Если это поле отсутствует, то при старте программа выбросит исключение и выведет в текстовую консоль ошибку config file is empty. Если отсутствует сам файл config.json, то будет выброшено исключение и выведется ошибка config file is missing.
  • name — поле с названием поискового движка. Оно может быть любым.
  • version — поле с номером версии поискового движка. Поле version должно совпадать с версией самого приложения, иначе будет выдаватся ошибка config.json has incorrect file version. Текущая версия движка 0.10.
  • max_responses — поле, определяющее один запрос.
  • files содержит пути к файлам, по которым необходимо осуществлять поиск. Внутри списка files лежат пути к файлам.
  • <путь к файлу>(“../resorces/file001.txt”) — это путь к файлу. Впоследствии по его содержимому будет произведён поиск. Если по этому пути файл не существует, то на экран выводится соответствующая ошибка, но выполнение программы не прекратится. При этом каждый документ содержит не более 1000 слов с максимальной длиной каждого в 100 символов. Слова состоят из строчных латинских букв и разделены одним или несколькими пробелами.

Файл пользовательских запросов

Пример описания файла requests.json:

{
  "requests": [
    "milk water",
    "sugar"
  ]
}

Разберём каждое поле файла requests.json подробнее.

  • requests состоит из списка запросов, которые впоследствии будут обработаны поисковым движком. Поле содержит не более 1000 запросов, каждый из которых включает от одного до десяти слов.
  • <содержимое запроса>(“some words”) — поисковый запрос, набор слов, разделённых одним или несколькими пробелами. По ним будет осуществлённ поиск. Все слова состоят из строчных латинских букв.

Файл ответов на пользовательские запросы

Пример описания файла answers.json:

{
  "answers":
      {
        "request000":
        {
          "relevance": 
                [
                  {"docid":2,"rank":1.0}
                ],
          "result":true
        },
        "request001": {
          "relevance": [
            {"docid":1,"rank":1.0}
          ],
          "result":true}
      }
}

answers — базовое поле в этом файле, которое содержит ответы на запросы.

  • request001 … 003 — идентификатор запроса, по которому сформирован ответ. Идентификатор запроса формируется автоматически по порядку, в котором находятся запросы в поле requests файла requests.json. Например:
"requests": [
    "some words..", для данной строки id запроса будет равен “request001”
    "some words..", для данной строки id запроса будет равен “request002”
    "some words..", для данной строки id запроса будет равен “request003”
    "some words..", для данной строки id запроса будет равен “request004”
    …
]
  • result – результат поиска запроса. Если он принимает значение true, значит по данному запросу найден хотя бы один документ. Если результат имеет значение false, значит ни одного документа не найдено. Тогда других полей в ответе на этот запрос нет.
  • relevance включается в файл answers.json, если на этот запрос удалось найти более одного документа.

Пример работы поискового движка

В начале настроим конфигурационный файл, как предстваленно ниже:

{
  "config": {
    "name": "SearchEngine",
    "version": "0.10",
    "max_responses": 5
  },
  "files": [
    "C:\\search_engine\\resources\\file001.txt",
    "C:\\search_engine\\resources\\file002.txt",
    "C:\\search_engine\\resources\\file003.txt",
    "C:\\search_engine\\resources\\file004.txt"
  ]
}

Затем пропишем пользовательские запросы в файле requests.json:

{
  "requests": [
    "milk water",
    "cappuccino salt"
  ]
}

И после этого создадим пару текстовых файлов для проверки поискового сервера:

milk milk milk milk water water water cappuccino
americano cappuccino salt milk water

Для запуска поискового движка необходимо открыть командную строку и перейти в директорию с проектом. И затем требуется прописать следующие команды:

  • Для Linux систем:
  ./cmake-build-debug/src/search_engine.exe
  • Для Windows систем:
   .\cmake-build-debug\src\search_engine.exe

В рассматриваемом случае программа должна в начале вывести два предупреждения связанные с отсутствием файлов file003.txt и file004.txt и затем произвести поиск заданных пользовательских запросов. Вывод программы представлен на рисунке ниже:

Result of the search engine

Файл answers.json после работы поискового движка:

{
 "answers": {
   "request000": {
     "relevance": [
       {
         "docid": 0,
         "rank": 1.0
       },
       {
         "docid": 1,
         "rank": 0.2857142984867096
       }
     ],
     "result": true
   },
   "request001": {
     "relevance": [
       {
         "docid": 1,
         "rank": 1.0
       }
     ],
     "result": true
   }
 }
}