Сравнить коммиты

...

16 Коммитов

Автор SHA1 Сообщение Дата
d9a2b3648a code: обработка ошибок 2025-05-21 16:28:29 +03:00
85eb559f72 code:работа с curl 2025-05-21 16:12:29 +03:00
9f5bbe976c code: добавлен argument count 2025-05-21 15:32:13 +03:00
b1c26a9503 code; установлены динамические библиотеки 2025-05-19 14:10:25 +03:00
ee9b12fc4f code:добавлен параметр bool prompt 2025-05-19 11:30:10 +03:00
30304c0921 code: переписана функция input_data 2025-05-16 18:15:43 +03:00
bb51ae70ea code: исходный код 2025-05-16 16:56:21 +03:00
7892d51950 code; исходный код 3 2025-05-16 16:49:09 +03:00
ccff7aed06 code: добавлен вывод процентов 2025-05-05 14:30:28 +03:00
9333e93a79 code: изменены svg 2025-05-03 15:21:02 +03:00
d2fae250dc code: добавлены svg 2025-05-03 15:08:38 +03:00
3f8b583bef code: добавлены тесты 2025-05-03 14:30:40 +03:00
455b1f3e75 code: добавлены doctest.h и unittest.cbp 2025-05-03 14:23:36 +03:00
968cd5f984 code: histogram_internal.h 2025-05-03 14:03:00 +03:00
b9c0dc0b22 code: добавлено разделение на файлы 2025-05-03 13:57:41 +03:00
3b74373fc3 code: добавлены раздельные функции 2025-05-03 13:40:28 +03:00
17 изменённых файлов: 7693 добавлений и 4 удалений

2
.gitignore поставляемый
Просмотреть файл

@@ -1,3 +1,5 @@
/bin
/obj
/lab1.layout
/curl
/lab1.depend

7106
doctest.h Обычный файл

Разница между файлами не показана из-за своего большого размера Загрузить разницу

42
histogram.cpp Обычный файл
Просмотреть файл

@@ -0,0 +1,42 @@
#include "histogram.h"
bool find_minmax(vector<double> vec, double& min, double& max) {
if (vec.size() == 0) {
cerr << "Empty vec";
return false;
}
min = vec[0];
max = vec[0];
for (double x : vec) {
if (x < min) {
min = x;
}
else if (x > max)
{
max = x;
}
}
return true;
}
vector<size_t> make_histogram(size_t number, vector<double> vec) {
vector<size_t> bins(number);
double mn, mx;
find_minmax(vec, mn, mx);
float bin_size = (mx - mn) / number;
for (size_t i = 0; i < vec.size(); i++) {
bool fl = false;
for (size_t j = 0; (j < number - 1) && !fl; j++) {
auto lo = mn + j * bin_size;
auto hi = mn + (j + 1) * bin_size;
if ((lo <= vec[i]) && (vec[i] < hi)) {
bins[j]++;
fl = true;
}
}
if (!fl) {
bins[number - 1]++;
}
}
return bins;
}

8
histogram.h Обычный файл
Просмотреть файл

@@ -0,0 +1,8 @@
#ifndef HISTOGRAM_H_INCLUDED
#define HISTOGRAM_H_INCLUDED
#include <vector>
#include <iostream>
using namespace std;
vector<size_t> make_histogram(size_t number, vector<double> vec);
#endif // HISTOGRAM_H_INCLUDED

5
histogram_internal.h Обычный файл
Просмотреть файл

@@ -0,0 +1,5 @@
#ifndef HISTOGRAM_INTERNAL_H_INCLUDED
#define HISTOGRAM_INTERNAL_H_INCLUDED
bool find_minmax(std::vector<double> vec, double& min, double& max);
#endif // HISTOGRAM_INTERNAL_H_INCLUDED

Просмотреть файл

@@ -31,8 +31,28 @@
<Compiler>
<Add option="-Wall" />
<Add option="-fexceptions" />
<Add directory="C:/Users/Professional/Desktop/cs-lab34/lab1/curl/include" />
</Compiler>
<Linker>
<Add library="C:/Users/Professional/Desktop/cs-lab34/lab1/curl/lib/libcurl.dll.a" />
<Add directory="C:/Users/Professional/Desktop/cs-lab34/lab1/curl/lib" />
</Linker>
<Unit filename="histogram.cpp" />
<Unit filename="histogram.h">
<Option target="&lt;{~None~}&gt;" />
</Unit>
<Unit filename="histogram_internal.h">
<Option target="&lt;{~None~}&gt;" />
</Unit>
<Unit filename="main.cpp" />
<Unit filename="svg.cpp" />
<Unit filename="svg.h">
<Option target="&lt;{~None~}&gt;" />
</Unit>
<Unit filename="text.cpp" />
<Unit filename="text.h">
<Option target="&lt;{~None~}&gt;" />
</Unit>
<Extensions>
<lib_finder disable_auto="1" />
</Extensions>

85
lab1.depend Обычный файл
Просмотреть файл

@@ -0,0 +1,85 @@
# depslib dependency file v1.0
1747403716 source:c:\users\professional\desktop\cs-lab34\lab1\histogram.cpp
"histogram.h"
1747403716 c:\users\professional\desktop\cs-lab34\lab1\histogram.h
<vector>
<iostream>
1747403716 source:c:\users\professional\desktop\cs-lab34\lab1\text.cpp
"text.h"
1747403716 c:\users\professional\desktop\cs-lab34\lab1\text.h
<iostream>
<vector>
1747651892 source:c:\users\professional\desktop\cs-lab34\lab1\main.cpp
<curl/curl.h>
"histogram.h"
"text.h"
"svg.h"
<iostream>
<vector>
1747403716 c:\users\professional\desktop\cs-lab34\lab1\svg.h
<iostream>
<vector>
<string>
<math.h>
1747403716 source:c:\users\professional\desktop\cs-lab34\lab1\svg.cpp
"svg.h"
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\curl.h
"curlver.h"
"system.h"
<stdio.h>
<limits.h>
<sys/param.h>
<sys/types.h>
<time.h>
<winsock2.h>
<ws2tcpip.h>
<sys/select.h>
<sys/socket.h>
<sys/time.h>
"easy.h"
"multi.h"
"urlapi.h"
"options.h"
"header.h"
"websockets.h"
"mprintf.h"
"typecheck-gcc.h"
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\curlver.h
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\system.h
<ConditionalMacros.h>
<inttypes.h>
<inttypes.h>
<sys/types.h>
<sys/socket.h>
<sys/poll.h>
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\easy.h
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\multi.h
"curl.h"
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\urlapi.h
"curl.h"
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\options.h
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\header.h
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\websockets.h
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\mprintf.h
<stdarg.h>
<stdio.h>
"curl.h"
1743562062 c:\users\professional\desktop\cs-lab34\lab1\curl\include\curl\typecheck-gcc.h

Просмотреть файл

@@ -1,9 +1,68 @@
#include <iostream>
#include <curl/curl.h>
#include "histogram.h"
#include "text.h"
#include "svg.h"
#include <vector>
using namespace std;
int main()
{
cout << "Hello world!" << endl;
struct Input {
vector<double> vec;
size_t korz{};
};
Input input_data(istream &in, bool prompt) {
Input data;
size_t n, korz;
if (prompt) {
cerr << "Number of elements: ";
}
in >> n;
data.vec.resize(n);
if (prompt) {
cerr << "Elements: ";
}
for (size_t i = 0; i < n; i++) {
in >> data.vec[i];
}
if (prompt) {
cerr << "Enter bin count: ";
}
in >> korz;
data.korz = korz;
return data;
}
int main(int argc, char* argv[]) {
curl_global_init(CURL_GLOBAL_ALL);
if (argc > 1) {
const char *url = argv[1];
CURL *curl = curl_easy_init();
if (curl) {
curl_easy_setopt(curl, CURLOPT_URL, url);
CURLcode res = curl_easy_perform(curl);
if (res != CURLE_OK) {
cerr << "curl_easy_perform() failed: " << curl_easy_strerror(res) << endl;
exit(1);
}
curl_easy_cleanup(curl);
}
return 0;
}
auto in_with_prompt = input_data(cin, true);
auto bins_with_prompt = make_histogram(in_with_prompt.korz, in_with_prompt.vec);
show_histogram_svg(bins_with_prompt);
return 0;
}

73
svg.cpp Обычный файл
Просмотреть файл

@@ -0,0 +1,73 @@
#include "svg.h"
using namespace std;
void
svg_begin(double width, double height)
{
cout << "<?xml version='1.0' encoding='UTF-8'?>\n";
cout << "<svg ";
cout << "width='" << width << "' ";
cout << "height='" << height << "' ";
cout << "viewBox='0 0 " << width << " " << height << "' ";
cout << "xmlns='http://www.w3.org/2000/svg'>\n";
}
void
svg_end()
{
cout << "</svg>\n";
}
void
svg_text(double left, double baseline, string text)
{
cout << "<text x='" << left << "' y='" << baseline << "'>" << text << "</text>";
}
void
svg_rect(double x, double y, double width, double height, string stroke = "black", string fill = "black")
{
cout << "<rect x='" << x << "' y='" << y << "' width='" << width << "' height='" << height << "' stroke='" << stroke << "' fill='" << fill << "' />";
}
void
show_histogram_svg(const vector<size_t>& bins)
{
const auto IMAGE_WIDTH = 400;
const auto IMAGE_HEIGHT = 300;
const auto TEXT_LEFT = 20;
const auto TEXT_BASELINE = 20;
const auto TEXT_WIDTH = 50;
const auto BIN_HEIGHT = 30;
const auto BLOCK_WIDTH = 10;
const auto GREEN = "green";
const auto RED = "red";
const auto MAX_WIDTH = IMAGE_WIDTH - TEXT_WIDTH;
svg_begin(IMAGE_WIDTH,IMAGE_HEIGHT);
double top = 0;
double max_count = bins[0];
for (size_t i = 0; i < bins.size(); i++)
{
if (max_count < bins[i])
{
max_count = bins[i];
}
}
for (size_t bin : bins)
{
double bin_width = (MAX_WIDTH) * (bin/max_count);
svg_text(TEXT_LEFT, top + TEXT_BASELINE, to_string(bin));
svg_rect(TEXT_WIDTH, top, bin_width, BIN_HEIGHT, GREEN, RED);
top += BIN_HEIGHT;
}
svg_end();
}

11
svg.h Обычный файл
Просмотреть файл

@@ -0,0 +1,11 @@
#ifndef SVG_H_INCLUDED
#define SVG_H_INCLUDED
#include <iostream>
#include <vector>
#include <string>
#include <math.h>
using namespace std;
void show_histogram_svg(const vector<size_t>& bins);
#endif // SVG_H_INCLUDED

82
text.cpp Обычный файл
Просмотреть файл

@@ -0,0 +1,82 @@
#include "text.h"
void show_histogram(std::vector<size_t> bins) {
bool gigant = false;
auto spaces = 0;
size_t mx_count = 0;
for (auto x : bins) {
if (x > 76) {
gigant = true;
}
if (x > mx_count) {
mx_count = x;
}
auto len = 0;
while (x > 0) {
x /= 10;
len++;
}
if (len > spaces) {
spaces = len;
}
}
if (spaces == 1) {
for (size_t i = 0; i < bins.size(); i++) {
std::cout << " " << bins[i] << "|";
if (gigant) {
if (bins[i] == mx_count) {
for (size_t j = 0; j < 76; j++) {
std::cout << "*";
}
}
else
{
for (size_t j = 0; j < 76 * static_cast<double>(bins[i]) / mx_count; j++) {
std::cout << "*";
}
}
}
else
{
for (size_t j = 0; j < bins[i]; j++) {
std::cout << "*";
}
std::cout << std::endl;
}
}
}
else
{
for (size_t i = 0; i < bins.size(); i++) {
int len = 1;
int k = bins[i];
for (; k /= 10; ++len);
while (len < spaces) {
std::cout << " ";
len++;
}
std::cout << bins[i];
std::cout << "|";
if (gigant) {
if (bins[i] == mx_count) {
for (size_t j = 0; j < 76; j++) {
std::cout << "*";
}
}
else
{
for (size_t j = 0; j < (76 * static_cast<double>(bins[i]) / mx_count - 1); j++) {
std::cout << "*";
}
}
}
else
{
for (size_t j = 0; j < bins[i]; j++) {
std::cout << "*";
}
}
std::cout << std::endl;
}
}
}

8
text.h Обычный файл
Просмотреть файл

@@ -0,0 +1,8 @@
#ifndef TEXT_H_INCLUDED
#define TEXT_H_INCLUDED
#include <iostream>
#include <vector>
void show_histogram(std::vector<size_t> bins);
#endif // TEXT_H_INCLUDED

41
unittest.cbp Обычный файл
Просмотреть файл

@@ -0,0 +1,41 @@
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<CodeBlocks_project_file>
<FileVersion major="1" minor="6" />
<Project>
<Option title="unittest" />
<Option pch_mode="2" />
<Option compiler="gcc" />
<Build>
<Target title="Debug">
<Option output="bin/Debug/unittest" prefix_auto="1" extension_auto="1" />
<Option object_output="obj/Debug/" />
<Option type="1" />
<Option compiler="gcc" />
<Compiler>
<Add option="-g" />
</Compiler>
</Target>
<Target title="Release">
<Option output="bin/Release/unittest" prefix_auto="1" extension_auto="1" />
<Option object_output="obj/Release/" />
<Option type="1" />
<Option compiler="gcc" />
<Compiler>
<Add option="-O2" />
</Compiler>
<Linker>
<Add option="-s" />
</Linker>
</Target>
</Build>
<Compiler>
<Add option="-Wall" />
</Compiler>
<Unit filename="histogram.cpp" />
<Unit filename="histogram_internal.h" />
<Unit filename="unittest.cpp" />
<Extensions>
<lib_finder disable_auto="1" />
</Extensions>
</Project>
</CodeBlocks_project_file>

64
unittest.cpp Обычный файл
Просмотреть файл

@@ -0,0 +1,64 @@
#define DOCTEST_CONFIG_NO_MULTITHREADING
#define DOCTEST_CONFIG_IMPLEMENT_WITH_MAIN
#include "doctest.h"
#include "histogram_internal.h"
using namespace std;
TEST_CASE("distinct positive numbers") {
double min = 0;
double max = 0;
find_minmax({1, 2}, min, max);
CHECK(min == 1);
CHECK(max == 2);
}
TEST_CASE("empty vector"){
double min = 0;
double max = 0;
vector<double> empty;
bool result = find_minmax(empty, min, max);
CHECK(!result);
}
TEST_CASE("vector of the same elements"){
double min = 0;
double max = 0;
find_minmax({3,3,3}, min, max);
CHECK(min == 3);
CHECK(max == 3);
}
TEST_CASE("vector of one elements"){
double min = 0;
double max = 0;
find_minmax({3}, min, max);
CHECK(min == max);
}
TEST_CASE("mixed positive and negative numbers") {
double min = 0;
double max = 0;
find_minmax({-1, 2, 0, -3, 5}, min, max);
CHECK(min == -3);
CHECK(max == 5);
}
TEST_CASE("vector with all negative numbers") {
double min = 0;
double max = 0;
find_minmax({-5, -10, -2}, min, max);
CHECK(min == -10);
CHECK(max == -2);
}
TEST_CASE("vector with zero") {
double min = 0;
double max = 0;
find_minmax({0, -1, 1}, min, max);
CHECK(min == -1);
CHECK(max == 1);
}
TEST_CASE("vector with procent"){
std::vector<size_t> vec {1,2,1};
auto res = make_percentages (vec);
CHECK(res[0] == 25);
}

68
unittest.depend Обычный файл
Просмотреть файл

@@ -0,0 +1,68 @@
# depslib dependency file v1.0
1746444035 source:c:\users\professional\desktop\cs-lab34\lab1\histogram.cpp
"histogram.h"
<cmath>
1746443248 c:\users\professional\desktop\cs-lab34\lab1\histogram.h
<vector>
<iostream>
<<<<<<< HEAD
1746447653 source:c:\users\professional\desktop\cs-lab34\lab1\unittest.cpp
=======
1746274690 source:c:\users\professional\desktop\cs-lab34\lab1\unittest.cpp
>>>>>>> ccff7aed06ddfe57aff6a2785558e2c335f8cf61
"doctest.h"
"histogram_internal.h"
1746271199 c:\users\professional\desktop\cs-lab34\lab1\doctest.h
<signal.h>
<ciso646>
<cstddef>
<ostream>
<istream>
<type_traits>
"doctest_fwd.h"
<ctime>
<cmath>
<climits>
<math.h>
<new>
<cstdio>
<cstdlib>
<cstring>
<limits>
<utility>
<fstream>
<sstream>
<iostream>
<algorithm>
<iomanip>
<vector>
<atomic>
<mutex>
<set>
<map>
<unordered_set>
<exception>
<stdexcept>
<csignal>
<cfloat>
<cctype>
<cstdint>
<string>
<sys/types.h>
<unistd.h>
<sys/sysctl.h>
<AfxWin.h>
<windows.h>
<io.h>
<sys/time.h>
<unistd.h>
<<<<<<< HEAD
1746447694 c:\users\professional\desktop\cs-lab34\lab1\histogram_internal.h
=======
1746444163 c:\users\professional\desktop\cs-lab34\lab1\histogram_internal.h
>>>>>>> ccff7aed06ddfe57aff6a2785558e2c335f8cf61

15
unittest.layout Обычный файл
Просмотреть файл

@@ -0,0 +1,15 @@
<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>
<CodeBlocks_layout_file>
<FileVersion major="1" minor="0" />
<ActiveTarget name="Debug" />
<File name="unittest.cpp" open="1" top="1" tabpos="1" split="0" active="1" splitpos="0" zoom_1="0" zoom_2="0">
<Cursor>
<Cursor1 position="1494" topLine="36" />
</Cursor>
</File>
<File name="histogram_internal.h" open="0" top="0" tabpos="0" split="0" active="1" splitpos="0" zoom_1="0" zoom_2="0">
<Cursor>
<Cursor1 position="193" topLine="0" />
</Cursor>
</File>
</CodeBlocks_layout_file>

Двоичные данные
unittest.o Обычный файл

Двоичный файл не отображается.