Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
S
strandstring
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Model registry
Operate
Environments
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Erik Strand
strandstring
Commits
118ddbdb
Commit
118ddbdb
authored
6 years ago
by
Erik Strand
Browse files
Options
Downloads
Patches
Plain Diff
First electrically complete board design
parent
b791e9ab
No related branches found
No related tags found
No related merge requests found
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
node_board/main.cpp
+65
-41
65 additions, 41 deletions
node_board/main.cpp
with
65 additions
and
41 deletions
node_board/main.cpp
+
65
−
41
View file @
118ddbdb
...
@@ -18,7 +18,7 @@ public:
...
@@ -18,7 +18,7 @@ public:
min_cut_thickness_px_
(
to_px
(
min_cut_thickness_
))
min_cut_thickness_px_
(
to_px
(
min_cut_thickness_
))
{
{
png_writer_
.
allocate
(
width_px_
,
height_px_
);
png_writer_
.
allocate
(
width_px_
,
height_px_
);
png_writer_
.
set_all_pixels
(
255
);
png_writer_
.
set_all_pixels
_black
(
);
}
}
int32_t
to_px
(
double
x
)
{
int32_t
to_px
(
double
x
)
{
...
@@ -95,59 +95,83 @@ int main() {
...
@@ -95,59 +95,83 @@ int main() {
// SOIC dims
// SOIC dims
double
const
pad_width
=
0.6
;
double
const
pad_width
=
0.6
;
double
const
pad_height
=
2.4
;
double
const
pad_height
=
2.4
;
//double const soic_width = 5;
double
const
soic_height
=
7
;
double
const
soic_height
=
7
;
double
const
soic_pitch
=
1.27
;
double
const
soic_pitch
=
1.27
;
// SOIC pads
// SOIC pads
double
const
soic_pos_x
=
min_trace_thickness
+
min_cut_thickness
;
double
const
soic_x_min
=
min_trace_thickness
+
min_cut_thickness
;
double
const
soic_x_max
=
soic_x_min
+
3
*
soic_pitch
+
pad_width
;
double
const
soic_btm_y
=
0.5
*
(
height
-
soic_height
);
double
const
soic_btm_y
=
0.5
*
(
height
-
soic_height
);
double
const
soic_top_y
=
height
-
soic_btm_y
;
double
const
soic_top_y
=
height
-
soic_btm_y
;
for
(
int32_t
i
=
0
;
i
<
4
;
++
i
)
{
for
(
int32_t
i
=
0
;
i
<
4
;
++
i
)
{
pad_x_min
=
soic_
pos_x
+
i
*
soic_pitch
;
pad_x_min
=
soic_
x_min
+
i
*
soic_pitch
;
pad_x_max
=
pad_x_min
+
pad_width
;
pad_x_max
=
pad_x_min
+
pad_width
;
pad_y_max
=
soic_btm_y
+
pad_height
;
pad_y_max
=
soic_btm_y
+
pad_height
;
board
.
draw_
pad
(
pad_x_min
,
pad_x_max
,
soic_btm_y
,
pad_y_max
);
board
.
draw_
rectangle
(
pad_x_min
,
pad_x_max
,
soic_btm_y
,
pad_y_max
);
pad_y_min
=
soic_top_y
-
pad_height
;
pad_y_min
=
soic_top_y
-
pad_height
;
board
.
draw_
pad
(
pad_x_min
,
pad_x_max
,
pad_y_min
,
soic_top_y
);
board
.
draw_
rectangle
(
pad_x_min
,
pad_x_max
,
pad_y_min
,
soic_top_y
);
}
}
// Data/VCC divider
// Ground pads and traces
pad_x_min
+=
pad_width
+
min_cut_thickness
+
min_trace_thickness
;
pad_x_max
=
pad_x_min
+
min_cut_thickness
;
pad_y_min
=
soic_btm_y
-
min_cut_thickness
;
pad_y_max
=
soic_top_y
+
min_cut_thickness
;
std
::
cout
<<
"Power trace is "
<<
width
-
pad_x_max
<<
"mm
\n
"
;
board
.
draw_rectangle
(
pad_x_min
,
pad_x_max
,
pad_y_min
,
pad_y_max
,
0
);
// Ground/data divider
pad_x_min
=
min_trace_thickness
;
pad_x_max
=
pad_x_min
+
min_cut_thickness
;
board
.
draw_rectangle
(
pad_x_min
,
pad_x_max
,
soic_btm_y
,
soic_top_y
,
0
);
// Ground pad links
pad_x_min
+=
min_cut_thickness
+
0.5
*
(
pad_width
-
min_trace_thickness
);
pad_x_max
=
pad_x_min
+
min_trace_thickness
;
pad_y_min
=
soic_btm_y
-
min_cut_thickness
;
pad_y_max
=
soic_btm_y
;
board
.
draw_rectangle
(
pad_x_min
,
pad_x_max
,
pad_y_min
,
pad_y_max
,
255
);
// Data and power pad links
pad_y_min
=
soic_top_y
-
pad_height
-
min_cut_thickness
;
pad_y_max
=
soic_top_y
+
min_cut_thickness
;
board
.
draw_rectangle
(
pad_x_min
,
pad_x_max
,
pad_y_min
,
pad_y_max
,
255
);
pad_x_min
+=
soic_pitch
;
pad_x_max
+=
soic_pitch
;
board
.
draw_rectangle
(
pad_x_min
,
pad_x_max
,
pad_y_min
,
pad_y_max
,
255
);
// Cable attachment dividers
double
const
cable_pad_width
=
(
width
-
2
*
min_cut_thickness
)
/
3
;
double
const
cable_pad_width
=
(
width
-
2
*
min_cut_thickness
)
/
3
;
pad_x_min
=
cable_pad_width
;
double
const
cable_pad_height
=
soic_btm_y
-
min_cut_thickness
;
pad_x_max
=
pad_x_min
+
min_cut_thickness
;
board
.
draw_rectangle
(
0
,
cable_pad_width
,
0
,
cable_pad_height
);
board
.
draw_rectangle
(
pad_x_min
,
pad_x_max
,
0
,
soic_btm_y
-
min_cut_thickness
,
0
);
board
.
draw_rectangle
(
0
,
min_trace_thickness
,
0
,
height
);
pad_x_min
+=
cable_pad_width
+
min_cut_thickness
;
board
.
draw_rectangle
(
soic_x_min
+
0.5
*
(
pad_width
-
min_trace_thickness
),
pad_x_max
=
pad_x_min
+
min_cut_thickness
;
soic_x_min
+
0.5
*
(
pad_width
-
min_trace_thickness
)
+
min_trace_thickness
,
board
.
draw_rectangle
(
pad_x_min
,
pad_x_max
,
0
,
soic_btm_y
-
2
*
min_cut_thickness
,
0
);
cable_pad_height
,
cable_pad_height
+
min_cut_thickness
);
board
.
draw_rectangle
(
0
,
cable_pad_width
,
soic_top_y
+
2
*
min_cut_thickness
+
min_trace_thickness
,
height
);
// Data pads and traces
double
const
data_pad_x_min
=
cable_pad_width
+
min_cut_thickness
;
double
const
data_pad_x_max
=
data_pad_x_min
+
cable_pad_width
;
board
.
draw_rectangle
(
data_pad_x_min
,
data_pad_x_max
,
0
,
cable_pad_height
);
board
.
draw_rectangle
(
data_pad_x_max
,
soic_x_max
+
min_cut_thickness
+
min_trace_thickness
,
cable_pad_height
-
min_cut_thickness
,
cable_pad_height
);
board
.
draw_rectangle
(
soic_x_max
+
min_cut_thickness
,
soic_x_max
+
min_cut_thickness
+
min_trace_thickness
,
cable_pad_height
,
soic_btm_y
+
pad_height
+
min_cut_thickness
);
board
.
draw_rectangle
(
soic_x_min
+
0.5
*
(
pad_width
-
min_trace_thickness
),
soic_x_max
+
min_cut_thickness
+
min_trace_thickness
,
soic_btm_y
+
pad_height
+
min_cut_thickness
,
soic_btm_y
+
pad_height
+
min_cut_thickness
+
min_trace_thickness
);
board
.
draw_rectangle
(
soic_x_min
+
0.5
*
(
pad_width
-
min_trace_thickness
),
soic_x_min
+
0.5
*
(
pad_width
-
min_trace_thickness
)
+
min_trace_thickness
,
soic_btm_y
+
pad_height
+
min_cut_thickness
,
soic_top_y
+
min_cut_thickness
);
board
.
draw_rectangle
(
soic_x_min
+
0.5
*
(
pad_width
-
min_trace_thickness
),
data_pad_x_max
,
soic_top_y
+
min_cut_thickness
,
soic_top_y
+
min_cut_thickness
+
min_trace_thickness
);
board
.
draw_rectangle
(
data_pad_x_min
,
data_pad_x_max
,
soic_top_y
+
min_cut_thickness
,
height
);
// VCC pads and traces
double
const
vcc_pad_x_min
=
2
*
(
cable_pad_width
+
min_cut_thickness
);
board
.
draw_rectangle
(
vcc_pad_x_min
,
width
,
0
,
cable_pad_height
-
min_cut_thickness
-
min_trace_thickness
);
board
.
draw_rectangle
(
width
-
min_trace_thickness
,
width
,
0
,
height
);
board
.
draw_rectangle
(
vcc_pad_x_min
,
width
,
height
-
cable_pad_height
,
height
);
double
const
vcc_pin_x
=
soic_x_min
+
soic_pitch
+
0.5
*
(
pad_width
-
min_trace_thickness
);
board
.
draw_rectangle
(
vcc_pin_x
,
width
,
soic_top_y
-
pad_height
-
min_cut_thickness
-
min_trace_thickness
,
soic_top_y
-
pad_height
-
min_cut_thickness
);
board
.
draw_rectangle
(
vcc_pin_x
,
vcc_pin_x
+
min_trace_thickness
,
soic_top_y
-
pad_height
-
min_cut_thickness
,
soic_top_y
);
board
.
save
(
"node_board_traces.png"
);
board
.
save
(
"node_board_traces.png"
);
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment