Игра на миллион

Ничего не буду от себя добавлять, читаем, смотрим, вносим посильный вклад.
А вдруг новые панфиловцы получатся. Или русский Wargaming :)



Оторвитесь ненадолго от беспощадного ЛУТа!
Две недели решат судьбу проекта.

PS:
Таки добавлю дескрипшн.
А то, похоже, многие осуждают, не читая.
Каждый из нас задумывался, как сложилась бы судьба нашей страны, если бы Александр Невский не победил на Чудском озере, или если бы большевики не пришли к власти. Как бы мы жили, если бы Горбачев не развалил СССР, или если майдан в Киеве был бы предотвращен. Теперь у вас есть реальный шанс узнать это! В нашей новой игре каждый от мала до велика сможет примерить на себя роль Верховного Правителя, лично управлять Россией, и повлиять на её историю и исход всех значительных исторических событий на протяжении столетий. Я предлагаю вам вместе сделать эту хорошую и полезную игру.

Наша игра построена на принятии решений. В самом начале игроку нужно выбрать кампанию: период в истории России и соответствующего ему правителя. Вместе с властью на игрока сваливаются и проблемы – будь то война или революция, тяжелое внешнеполитическое положение или внутренние проблемы в стране. Для решения проблем у игрока в распоряжении будут иметься различные ресурсы – военный, экономический, социальный и так далее. Помогать в решении сложных вопросов игроку будут советники – генералы, министры и прочие значимые исторические фигуры.

В ходе игры, будут происходить исторические события, на которые игрок должен отреагировать — принять то или иное решение. В зависимости от наличия ресурсов, лояльности советников и многих других факторов (в том числе и от предыдущих решений!) у игрока будет набор вариантов того, что он может сделать.

Простых решений в «Империи» не будет

--

---

W5100 Вопрос

Здравствуйте, почти уже сделал проект при помощи wiznet w5100, но тут мне понадобилось разрешить доступ к сайту с определённого IP. И вот тут возник вопрос где его взять ?? При использовании UDP протокола там в заголовке передаётся информация IP, порт и ещё чего-то. А в TCP сразу считывается HTTP заголовок в котором только ip хоста указанно.
В скором времени планируется переход на w5500 может там чего есть?
  • -7
  • 12 декабря 2013, 08:16
  • pokk

STM32F407, Timer+USART

Добрый вечер. Пишу программу которая каждую секунду будет отсылать по USART переменную увеличивающуюся на единицу. Не отправляет. Не пойму в чем проблема. Помогите разобраться!
#include "stm32f4xx.h"
#include "stm32f4xx_rcc.h"
#include "stm32f4xx_gpio.h"
#include "stm32f4xx_tim.h"
#include "stm32f4xx_exti.h"
#include "stm32f4xx_syscfg.h"
#include "stm32f4xx_usart.h"
#include "misc.h"
#include <stdlib.h>
void usart_init(void)
{
  GPIO_InitTypeDef GPIO_InitStructure;
  USART_InitTypeDef USART_InitStructure;

  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC, ENABLE);
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);

  GPIO_PinAFConfig(GPIOC, GPIO_PinSource10, GPIO_AF_USART3);
  GPIO_PinAFConfig(GPIOC, GPIO_PinSource11, GPIO_AF_USART3);

  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;

  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOC, &GPIO_InitStructure);

  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
  GPIO_Init(GPIOC, &GPIO_InitStructure);

  USART_InitStructure.USART_BaudRate = 19200;
  USART_InitStructure.USART_WordLength = USART_WordLength_8b;
  USART_InitStructure.USART_StopBits = USART_StopBits_1;
  USART_InitStructure.USART_Parity = USART_Parity_No;
  USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
  USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;

  USART_Init(USART3, &USART_InitStructure);
  USART_ITConfig(USART3,USART_IT_RXNE,ENABLE);
  USART_Cmd(USART3, ENABLE);
}
void usart_send(char byte)
{
	  USART_SendData(USART3,byte);
	  while (USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET){}
}

void usart_send_text(char *buffer)
{
	while (*buffer)
	{
		usart_send(*buffer);
		buffer++;
	}
}
void init_timer(){
	TIM_TimeBaseInitTypeDef base_timer;
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM6, ENABLE); 
	TIM_TimeBaseStructInit(&base_timer);
	base_timer.TIM_Prescaler = 24000000 - 1;
	base_timer.TIM_Period = 1000;
	TIM_TimeBaseInit(TIM6, &base_timer);

	TIM_ITConfig(TIM6, TIM_IT_Update, ENABLE);
	TIM_Cmd(TIM6, ENABLE);  

	NVIC_EnableIRQ(TIM6_DAC_IRQn);
}
u16 i = 0;
char p[100];
void TIM6_DAC_IRQHandler()
{
    if (TIM_GetITStatus(TIM6, TIM_IT_Update) != RESET) 
			{
      TIM_ClearITPendingBit(TIM6, TIM_IT_Update);
			i++;
                        sprintf (p,"%d",i);
			usart_send_text(p);
      }
		
}
int main(){
init_timer();
usart_init();
do {
} while(1);
}
  • -16
  • 24 ноября 2013, 22:10
  • Foxek

STM32F407VG, ADC+DMA+USART

Написал программу ADC+DMA+USART.Микроконтроллер STM32F407VG. Почему-то не работает. Не могу понять почему… Суть программы: При подаче напряжения на выход АЦП, DMA2 передает данные в память после чего DMA1 передает данные в USART3 который шлет все в PC

/*******************************************************************/
#include "stm32f4xx.h"
#include "stm32f4xx_rcc.h"
#include "stm32f4xx_gpio.h"
#include "stm32f4xx_adc.h"
#include "stm32f4xx_exti.h"
#include "stm32f4xx_syscfg.h"
#include "stm32f4xx_usart.h"
#include "stm32f4xx_dma.h"
#include "misc.h"
/*******************************************************************/
uint16_t adc_buffer[64];
void ADC_INIT(void)
{
//ADC Initialization
ADC_InitTypeDef  ADC_InitStructure;
ADC_InitStructure.ADC_ScanConvMode = DISABLE;
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_Ext_IT11;
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
ADC_InitStructure.ADC_NbrOfConversion = 1;
ADC_Init(ADC1, &ADC_InitStructure);

ADC_RegularChannelConfig(ADC1, ADC_Channel_6, 1, ADC_SampleTime_3Cycles);
ADC_DMARequestAfterLastTransferCmd(ADC1, ENABLE);

//ADC On to work with DMA
ADC_DMACmd(ADC1, ENABLE);
ADC_Cmd(ADC1, ENABLE);
}




void USART_INIT(void)
{
GPIO_InitTypeDef GPIO_InitStruct;
USART_InitTypeDef USART_InitStructure;

// USART TX
    GPIO_PinAFConfig(GPIOB, GPIO_PinSource10, GPIO_AF_USART3);
		GPIO_InitStruct.GPIO_Pin = GPIO_Pin_10;
		GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN;
		GPIO_InitStruct.GPIO_OType = GPIO_OType_PP;
		GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;

		GPIO_Init(GPIOB, &GPIO_InitStruct);	
	
//USART Initialization
		USART_InitStructure.USART_BaudRate = 115200;
		USART_InitStructure.USART_WordLength = USART_WordLength_8b;
		USART_InitStructure.USART_StopBits = USART_StopBits_1;
		USART_InitStructure.USART_Parity = USART_Parity_No ;
		USART_InitStructure.USART_HardwareFlowControl =USART_HardwareFlowControl_None;
		USART_InitStructure.USART_Mode = USART_Mode_Tx;
		USART_Init(USART3, &USART_InitStructure);
		USART_Cmd(USART3, ENABLE);
		USART_DMACmd(USART3, USART_DMAReq_Tx, ENABLE);
}

void DMA1_USART(void)
{
	DMA_InitTypeDef DMA_InitStructure;
  DMA_InitStructure.DMA_Channel = DMA_Channel_4;  
  DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&(USART3->DR);
  DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)&adc_buffer[0];
  DMA_InitStructure.DMA_DIR = DMA_DIR_MemoryToPeripheral;
  DMA_InitStructure.DMA_BufferSize = 64;
  DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
  DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
  DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;
  DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;
  DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
  DMA_InitStructure.DMA_Priority = DMA_Priority_Low;
  DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;         
  DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull;
  DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
  DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
  DMA_Init(DMA1_Stream1, &DMA_InitStructure);
  DMA_Cmd(DMA1_Stream1, ENABLE);
}

void DMA2_INIT(void)
{
DMA_InitTypeDef DMA_InitStructure;
DMA_InitStructure.DMA_Channel = DMA_Channel_0;
DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t) &ADC1->DR;	
DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)&adc_buffer[0];	
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;
DMA_InitStructure.DMA_BufferSize = 64;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;
DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull;
DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
DMA_Init(DMA2_Stream0, &DMA_InitStructure);
 
DMA_Cmd(DMA2_Stream0, ENABLE);
DMA_ITConfig(DMA2_Stream0, DMA_IT_TC, ENABLE);   
}

void DMA2_Stream0_IRQHandler(void)
{ 
    DMA_ClearITPendingBit(DMA2_Stream0, DMA_IT_TCIF0);
  }
int main()
{
	NVIC_InitTypeDef NVIC_InitStructure;
	GPIO_InitTypeDef GPIO_InitStruct;
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE); 
	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_DMA2, ENABLE);
	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOE, ENABLE);
	RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3,ENABLE);
	
//GPIO Initialization For ADC1
	GPIO_InitStruct.GPIO_Pin = GPIO_Pin_11;
	GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN;
	GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_NOPULL;
	GPIO_Init(GPIOE, &GPIO_InitStruct);
	
//Interrapt from DMA
	NVIC_InitStructure.NVIC_IRQChannel = DMA2_Stream0_IRQn;
  NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
  NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
  NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  NVIC_Init(&NVIC_InitStructure);
	
    while(1)
    {
 	__NOP();
    }

}

  • -10
  • 12 ноября 2013, 02:12
  • Foxek

AVR готовые решения ,заготовки для проектов

Универсальный измерительный прибор (база: atmega8\atmega8l )
У меня был на панельке микроконтроллер.
www.ebay.com/sch/i.html?_from=R40&_sacat=0&_nkw=TRANSISTOR+TESTER+NPN+PNP+MOSFET&LH_BIN=1

Вариант с ESR (ATmega168)
www.ebay.com/sch/i.html?_from=R40&_sacat=0&_nkw=TESTER+CAPACITOR+ESR&LH_BIN=1

Автоперевод со странички автора:
translate.google.com/translate?hl=en&sl=de&tl=ru&u=http%3A%2F%2Fwww.mikrocontroller.net%2Farticles%2FAVR-Transistortester&sandbox=1

Особенности

Автоматическое обнаружение NPN и PNP транзисторы, N-и P-канальных МОП-транзисторов, диодов (в том числе двойные диоды), тиристоры, симисторы и резисторов и конденсаторов.
Автоматический расчет и отображение контактов компонента для тестирования
Обнаружение и отображение защитные диоды для транзисторов и МОП-транзисторов
Определении прибыли и база-эмиттер прямого напряжения на транзисторах
Измерение порогового напряжения затвора и емкость затвора МОП-транзистора
Отображения значений на текстовом ЖК-дисплей (2 * 16 символов)
Продолжительность тестирования компонентов: менее 2 секунд (за исключением больших конденсаторов)
Управление одной кнопкой, автоматическое отключение
Потребляемая мощность в выключенном состоянии: <20 нА

Есть прошивки с измерением ESR конденсаторов. (требуется atmega168)
translate.google.com/translate?hl=en&sl=de&tl=ru&u=http%3A%2F%2Fwww.mikrocontroller.net%2Farticles%2FAVR_Transistortester&sandbox=1

Введение

Оригинальный дизайн: www.mikrocontroller.net/articles/AVR-Transistortester

Дальнейшее развитие в работах Карла-Хайнца Kübbeler

Я продолжил проект транзистора тестером Маркус Frejek и специально разработанное программное обеспечение. Благодаря улучшенным свойствам имя уже было предложено компонентов тестера. Но я сам все еще видеть отличительной чертой в автоматическом определении типа транзистора и имущества, а разработанная Маркусом Frejek.

Здесь я хочу перечислить наиболее важные свойства

Работает с ATmega8, ATmega168 и ATmega328 процессоров.
Отображение результатов измерений на ЖК-2x16 характер.
Управление одной кнопкой с автоматическим отключением.
Устройство имеет три универсальных Meßports (тест PIN).
Автоматическое обнаружение NPN, PNP, N-и P-канальный МОП-транзистор, JFET, Импульсные диоды малой мощности и тиристорные и тиристорные.
Автоматическое распознавание выводов компонентов, компоненты могут быть подключены в любом случае.
Измерение коэффициента усиления по току и напряжение база-эмиттер для биполярных транзисторов, включая Дарлингтон.
Автоматическое обнаружение защитный диод для биполярных транзисторов и МОП-транзисторы.
До двух резисторов измеряется в измерения с разрешением до 0,1 Ом, диапазон простирается на более чем 50 МОм. Значения сопротивления менее 10 Ом отображаются для ATmega168/328 С помощью ЭПР-метода измерения с разрешением 0,01 Ом.
Подключенным конденсатором может быть измерено в диапазоне 35pF к 100mF с разрешением до 1 пФ.
Резисторов и конденсаторов показаны с их символами окружении соответствующие им номера контактов разъема.
Резистор и конденсатор значения могут отображаться до четырех знаков после запятой в правильном измерении.
До двух диодов также показаны flußrichtungsrichtig с его символическое представление, окруженный номера разъема и дополнительную информацию прямого напряжения.
Кроме того, отдельные значения емкости диода и версия 1.08k тока в обратном направлении измеряется.
ATmega168/328 для калибровки нулевой емкости, нулевого сопротивления и других параметров в самотестирования филиал возможно.
Для ATmega168/328 также индуктивности о 0.01mH могут быть обнаружены и измерены до 20H.
Для ATmega168/328 измерения ESR (эквивалентное последовательное сопротивление) интегрирован более 0:18 мкФ с разрешением 0,01 Ом.
ATmega168/328 VLOSS для потери напряжения рассматривается коллегией из зарядного импульса около 5 конденсаторов нФ. Таким образом, качество конденсаторов может быть оценена.

Более подробную информацию с примерами измерений можно прочитать в PDF документацией на немецком и английском языках.

Отступление…
Тут есть некоторое количество тупиц и оленей, поэтому сразу скажу:
1) Статья-заметка информативная, если надо и хотите узнать больше, кликайте по ссылкам, там есть все ответы.Моя задача — первичная информация.
2) Приведены описания взятые из автопереводчика гугла, да есть такая штука.
3) Если что-то не ясно читайте пункт 1)
  • -16
  • 30 августа 2013, 08:38
  • selevo

XControl. Управление через компьютер, телефон, планшет

Думаю, тем, кто интересуется бюджетным вариантом умного дома или просто автоматизацией, это будет интересно))))))
PS: Не сочтите за спам)))

XControl представляет из себя программно-аппаратный комплекс, с помощью которого можно управлять электроцепями, а так же, контролировать разнообразные датчики через компьютер, телефон или планшет. Система состоит из основного аппаратного блока и трех программ – XControl, которая предоставляет возможность просматривать одновременно за несколькими аппаратными блоками, программы XControl-Configer, с помощью которой устанавливаются основные настройки блока, а так же, программы XControl для платформы Android.



Читать дальше

Мощный фонарик за 15 минут

Недавно получил светодиоды с dealextreme на 90lm, 180lm.

Как раз некстати сдох старый фонарик, пришлось слепить на скорую руку.
Все что нужно — отсек на 4 АА батарейки, кнопка, кусок текстолита, SMD резисторы на 1..10 ОМ, паяльник, и термоклей.


Читать дальше
  • -7
  • 01 июня 2013, 00:15
  • zubb